repo_analyzer 1.4.0 → 1.6.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: bb655decd9592215cda4751bd7e134ad5252b2b292492b2d71771cb0fe2443ad
4
- data.tar.gz: c0c009b39bf8e30f23e198593ee42fd8e9616ee76e5b1074026434b9e0d61727
3
+ metadata.gz: b3ba0febd4ab0260ef41e02596f408eed4ce7841467be48339f95a6fe86ebe35
4
+ data.tar.gz: 58f19d2a5c0fc9708eedfbef74ed7930aabaf928679d8da5392a4533927dfb15
5
5
  SHA512:
6
- metadata.gz: b546db4302e6aeafd82fff62f77dbea3bab62e70b1ed6a7e98623c7f5cb540cd640633ad75cd1324efc5291c1d653f2cb699eee288a7a7f1a0c06222f2bd9aef
7
- data.tar.gz: 7ad4fdda952618118f75465f9e64fd21550df01a0234a237456b1ca210c13194b5d9155365d688fe934bc8a59dd808752d96031927e106a4e8b4e8d02a6831a0
6
+ metadata.gz: a14e02b846867e11384b3034b0d70076cbff20e005a32d0ca9d8eda05331276b79bcd931c0d48a66a6911da7ca861f77ef699aa5f9892f8cbb93eb4bbc2e9d89
7
+ data.tar.gz: c675a4d5e84b1624f1af32ec1abbaec1bb7daa3ce880d3c7731250257c77c7df02687c22a98858af208fc3a6b1d0ea38298ed1b74ac99b269abe23dd5fe884cf
data/CHANGELOG.md CHANGED
@@ -1,6 +1,18 @@
1
1
  # Change Log
2
2
  All notable changes to this project will be documented in this file.
3
3
  This project adheres to [Semantic Versioning](http://semver.org/).
4
+
5
+ ### v1.6.0
6
+ #### Added
7
+ * Complete [bundler-stats](https://github.com/jmmastey/bundler-stats) extractor data with potential removals
8
+
9
+ ### v1.5.0
10
+ #### Added
11
+
12
+ * Run analyze rake task with custom project path.
13
+ #### Fixed
14
+
15
+ * Remove [fasterer](https://github.com/DamirSvrtan/fasterer) extractor.
4
16
  ### v1.4.0
5
17
  #### Added
6
18
 
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- repo_analyzer (1.4.0)
4
+ repo_analyzer (1.6.0)
5
5
  brakeman
6
6
  bundler-audit
7
7
  bundler-stats
@@ -3,8 +3,24 @@ module RepoAnalyzer
3
3
  private
4
4
 
5
5
  def extracted_info
6
- result = `bundle exec bundle-stats stats -f json`
7
- JSON.parse(result)
6
+ stats['gems'] = gems_info
7
+ stats
8
+ end
9
+
10
+ def gems_info
11
+ gem_names.inject([]) do |memo, gem_name|
12
+ result = `bundle exec bundle-stats show '#{gem_name}' -f json`
13
+ memo << JSON.parse(result)
14
+ memo
15
+ end
16
+ end
17
+
18
+ def gem_names
19
+ stats['gems'].map { |gem| gem['name'] }
20
+ end
21
+
22
+ def stats
23
+ @stats ||= JSON.parse(`bundle exec bundle-stats stats -f json`)
8
24
  end
9
25
  end
10
26
  end
@@ -1,8 +1,8 @@
1
1
  module RepoAnalyzer
2
2
  class ExtractProjectInfoJob < ApplicationJob
3
- def perform(repo_name)
3
+ def perform(repo_name, project_path)
4
4
  project_info = {}
5
- bridge = RepoAnalyzer::ProjectDataBridge.new(repo_name)
5
+ bridge = RepoAnalyzer::ProjectDataBridge.new(repo_name, project_path)
6
6
 
7
7
  for_each_extractor do |extractor|
8
8
  extracted_data = extractor.new(bridge).extract
@@ -1,3 +1,3 @@
1
1
  module RepoAnalyzer
2
- VERSION = '1.4.0'
2
+ VERSION = '1.6.0'
3
3
  end
@@ -1,7 +1,9 @@
1
1
  namespace :repo_analyzer do
2
2
  desc "Extract repo info and post to defined endpoint"
3
- task :analyze, [:repo_name] => :environment do |_t, args|
4
- project_info = RepoAnalyzer::ExtractProjectInfoJob.perform_now(args.repo_name)
3
+ task :analyze, [:repo_name, :project_path] => :environment do |_t, args|
4
+ project_info = RepoAnalyzer::ExtractProjectInfoJob.perform_now(
5
+ args.repo_name, args.project_path
6
+ )
5
7
  RepoAnalyzer::PostExtractedInfoJob.perform_now(args.repo_name, project_info)
6
8
  end
7
9
  end
@@ -2,6 +2,29 @@ require 'rails_helper'
2
2
 
3
3
  describe RepoAnalyzer::BundlerStatsExtractor, repo_analyzer_extractor_helpers: true do
4
4
  describe "#extract" do
5
+ let(:rspec_junit_formatter) do
6
+ {
7
+ "name": "rspec_junit_formatter",
8
+ "total_dependencies": 2,
9
+ "first_level_dependencies": 1,
10
+ "top_level_dependencies": {},
11
+ "transitive_dependencies": [
12
+ "rspec-core (>= 2, < 4, != 2.12.0)",
13
+ "rspec-support (~> 3.12.0)"
14
+ ]
15
+ }
16
+ end
17
+
18
+ let(:sqlite) do
19
+ {
20
+ "name": "sqlite",
21
+ "total_dependencies": 0,
22
+ "first_level_dependencies": 0,
23
+ "top_level_dependencies": {},
24
+ "transitive_dependencies": []
25
+ }
26
+ end
27
+
5
28
  let(:stats) do
6
29
  {
7
30
  "summary": {
@@ -11,265 +34,8 @@ describe RepoAnalyzer::BundlerStatsExtractor, repo_analyzer_extractor_helpers: t
11
34
  "github": 0
12
35
  },
13
36
  "gems": [
14
- {
15
- "name": "repo_analyzer",
16
- "total_dependencies": 84,
17
- "first_level_dependencies": 14,
18
- "top_level_dependencies": {},
19
- "transitive_dependencies": [
20
- "brakeman (>= 0)",
21
- "bundler-audit (>= 0)",
22
- "bundler-stats (>= 0)",
23
- "faraday-retry (>= 0)",
24
- "fasterer (>= 0)",
25
- "octokit (~> 4.0)",
26
- "rails (>= 6.0)",
27
- "rails_best_practices (>= 0)",
28
- "reek (>= 0)",
29
- "rubocop (~> 1.9)",
30
- "rubocop-performance (>= 0)",
31
- "rubocop-platanus (~> 0.2)",
32
- "rubocop-rails (>= 0)",
33
- "rubocop-rspec (~> 2.2)",
34
- "bundler (>= 1.2.0, < 3)",
35
- "thor (~> 1.0)",
36
- "faraday (~> 2.0)",
37
- "faraday-net_http (>= 2.0, < 3.1)",
38
- "ruby2_keywords (>= 0.0.4)",
39
- "colorize (~> 0.7)",
40
- "ruby_parser (>= 3.19.1)",
41
- "sexp_processor (~> 4.16)",
42
- "sawyer (~> 0.9)",
43
- "addressable (>= 2.3.5)",
44
- "public_suffix (>= 2.0.2, < 6.0)",
45
- "actioncable (= 6.1.7)",
46
- "actionmailbox (= 6.1.7)",
47
- "actionmailer (= 6.1.7)",
48
- "actionpack (= 6.1.7)",
49
- "actiontext (= 6.1.7)",
50
- "actionview (= 6.1.7)",
51
- "activejob (= 6.1.7)",
52
- "activemodel (= 6.1.7)",
53
- "activerecord (= 6.1.7)",
54
- "activestorage (= 6.1.7)",
55
- "activesupport (= 6.1.7)",
56
- "railties (= 6.1.7)",
57
- "sprockets-rails (>= 2.0.0)",
58
- "nio4r (~> 2.0)",
59
- "websocket-driver (>= 0.6.1)",
60
- "rack (~> 2.0, >= 2.0.9)",
61
- "rack-test (>= 0.6.3)",
62
- "rails-dom-testing (~> 2.0)",
63
- "rails-html-sanitizer (~> 1.0, >= 1.2.0)",
64
- "builder (~> 3.1)",
65
- "erubi (~> 1.4)",
66
- "concurrent-ruby (~> 1.0, >= 1.0.2)",
67
- "i18n (>= 1.6, < 2)",
68
- "minitest (>= 5.1)",
69
- "tzinfo (~> 2.0)",
70
- "zeitwerk (~> 2.3)",
71
- "nokogiri (>= 1.6)",
72
- "mini_portile2 (~> 2.8.0)",
73
- "racc (~> 1.4)",
74
- "loofah (~> 2.3)",
75
- "crass (~> 1.0.2)",
76
- "websocket-extensions (>= 0.1.0)",
77
- "mail (>= 2.7.1)",
78
- "globalid (>= 0.3.6)",
79
- "marcel (~> 1.0)",
80
- "mini_mime (>= 1.1.0)",
81
- "net-imap (>= 0)",
82
- "net-pop (>= 0)",
83
- "net-smtp (>= 0)",
84
- "date (>= 0)",
85
- "net-protocol (>= 0)",
86
- "timeout (>= 0)",
87
- "method_source (>= 0)",
88
- "rake (>= 12.2)",
89
- "sprockets (>= 3.0.0)",
90
- "code_analyzer (~> 0.5.5)",
91
- "erubis (>= 0)",
92
- "json (>= 0)",
93
- "require_all (~> 3.0)",
94
- "ruby-progressbar (>= 0)",
95
- "kwalify (~> 0.7.0)",
96
- "parser (~> 3.2.0)",
97
- "rainbow (>= 2.0, < 4.0)",
98
- "rexml (~> 3.1)",
99
- "ast (~> 2.4.1)",
100
- "parallel (~> 1.10)",
101
- "regexp_parser (>= 1.8, < 3.0)",
102
- "rubocop-ast (>= 1.23.0, < 2.0)",
103
- "unicode-display_width (>= 1.4.0, < 3.0)"
104
- ]
105
- },
106
- {
107
- "name": "rspec-rails",
108
- "total_dependencies": 28,
109
- "first_level_dependencies": 7,
110
- "top_level_dependencies": {},
111
- "transitive_dependencies": [
112
- "actionpack (>= 6.1)",
113
- "activesupport (>= 6.1)",
114
- "railties (>= 6.1)",
115
- "rspec-core (~> 3.11)",
116
- "rspec-expectations (~> 3.11)",
117
- "rspec-mocks (~> 3.11)",
118
- "rspec-support (~> 3.11)",
119
- "actionview (= 6.1.7)",
120
- "rack (~> 2.0, >= 2.0.9)",
121
- "rack-test (>= 0.6.3)",
122
- "rails-dom-testing (~> 2.0)",
123
- "rails-html-sanitizer (~> 1.0, >= 1.2.0)",
124
- "builder (~> 3.1)",
125
- "erubi (~> 1.4)",
126
- "concurrent-ruby (~> 1.0, >= 1.0.2)",
127
- "i18n (>= 1.6, < 2)",
128
- "minitest (>= 5.1)",
129
- "tzinfo (~> 2.0)",
130
- "zeitwerk (~> 2.3)",
131
- "nokogiri (>= 1.6)",
132
- "mini_portile2 (~> 2.8.0)",
133
- "racc (~> 1.4)",
134
- "loofah (~> 2.3)",
135
- "crass (~> 1.0.2)",
136
- "method_source (>= 0)",
137
- "rake (>= 12.2)",
138
- "thor (~> 1.0)",
139
- "diff-lcs (>= 1.2.0, < 2.0)"
140
- ]
141
- },
142
- {
143
- "name": "factory_bot_rails",
144
- "total_dependencies": 24,
145
- "first_level_dependencies": 2,
146
- "top_level_dependencies": {},
147
- "transitive_dependencies": [
148
- "factory_bot (~> 6.2.0)",
149
- "railties (>= 5.0.0)",
150
- "activesupport (>= 5.0.0)",
151
- "concurrent-ruby (~> 1.0, >= 1.0.2)",
152
- "i18n (>= 1.6, < 2)",
153
- "minitest (>= 5.1)",
154
- "tzinfo (~> 2.0)",
155
- "zeitwerk (~> 2.3)",
156
- "actionpack (= 6.1.7)",
157
- "method_source (>= 0)",
158
- "rake (>= 12.2)",
159
- "thor (~> 1.0)",
160
- "actionview (= 6.1.7)",
161
- "rack (~> 2.0, >= 2.0.9)",
162
- "rack-test (>= 0.6.3)",
163
- "rails-dom-testing (~> 2.0)",
164
- "rails-html-sanitizer (~> 1.0, >= 1.2.0)",
165
- "builder (~> 3.1)",
166
- "erubi (~> 1.4)",
167
- "nokogiri (>= 1.6)",
168
- "mini_portile2 (~> 2.8.0)",
169
- "racc (~> 1.4)",
170
- "loofah (~> 2.3)",
171
- "crass (~> 1.0.2)"
172
- ]
173
- },
174
- {
175
- "name": "guard-rspec",
176
- "total_dependencies": 21,
177
- "first_level_dependencies": 3,
178
- "top_level_dependencies": {},
179
- "transitive_dependencies": [
180
- "guard (~> 2.1)",
181
- "guard-compat (~> 1.1)",
182
- "rspec (>= 2.99.0, < 4.0)",
183
- "formatador (>= 0.2.4)",
184
- "listen (>= 2.7, < 4.0)",
185
- "lumberjack (>= 1.0.12, < 2.0)",
186
- "nenv (~> 0.1)",
187
- "notiffany (~> 0.0)",
188
- "pry (>= 0.13.0)",
189
- "shellany (~> 0.0)",
190
- "thor (>= 0.18.1)",
191
- "rb-fsevent (~> 0.10, >= 0.10.3)",
192
- "rb-inotify (~> 0.9, >= 0.9.10)",
193
- "ffi (~> 1.0)",
194
- "coderay (~> 1.1)",
195
- "method_source (~> 1.0)",
196
- "rspec-core (~> 3.12.0)",
197
- "rspec-expectations (~> 3.12.0)",
198
- "rspec-mocks (~> 3.12.0)",
199
- "rspec-support (~> 3.12.0)",
200
- "diff-lcs (>= 1.2.0, < 2.0)"
201
- ]
202
- },
203
- {
204
- "name": "coveralls",
205
- "total_dependencies": 8,
206
- "first_level_dependencies": 5,
207
- "top_level_dependencies": {},
208
- "transitive_dependencies": [
209
- "json (>= 1.8, < 3)",
210
- "simplecov (~> 0.16.1)",
211
- "term-ansicolor (~> 1.3)",
212
- "thor (>= 0.19.4, < 2.0)",
213
- "tins (~> 1.6)",
214
- "docile (~> 1.1)",
215
- "simplecov-html (~> 0.10.0)",
216
- "sync (>= 0)"
217
- ]
218
- },
219
- {
220
- "name": "pry-rails",
221
- "total_dependencies": 3,
222
- "first_level_dependencies": 1,
223
- "top_level_dependencies": {},
224
- "transitive_dependencies": [
225
- "pry (>= 0.10.4)",
226
- "coderay (~> 1.1)",
227
- "method_source (~> 1.0)"
228
- ]
229
- },
230
- {
231
- "name": "pry",
232
- "total_dependencies": 2,
233
- "first_level_dependencies": 2,
234
- "top_level_dependencies": {
235
- "guard": "guard (2.18.0)",
236
- "guard-rspec": "guard-rspec (4.7.3)",
237
- "pry-rails": "pry-rails (0.3.9)"
238
- },
239
- "transitive_dependencies": [
240
- "coderay (~> 1.1)",
241
- "method_source (~> 1.0)"
242
- ]
243
- },
244
- {
245
- "name": "rspec_junit_formatter",
246
- "total_dependencies": 2,
247
- "first_level_dependencies": 1,
248
- "top_level_dependencies": {},
249
- "transitive_dependencies": [
250
- "rspec-core (>= 2, < 4, != 2.12.0)",
251
- "rspec-support (~> 3.12.0)"
252
- ]
253
- },
254
- {
255
- "name": "bundler",
256
- "total_dependencies": 0,
257
- "first_level_dependencies": 0,
258
- "top_level_dependencies": {
259
- "bundler-audit": "bundler-audit (0.9.1)",
260
- "bundler-stats": "bundler-stats (2.3.0)",
261
- "rails": "rails (6.1.7)",
262
- "repo_analyzer": "repo_analyzer (1.3.0)"
263
- },
264
- "transitive_dependencies": []
265
- },
266
- {
267
- "name": "sqlite3",
268
- "total_dependencies": 0,
269
- "first_level_dependencies": 0,
270
- "top_level_dependencies": {},
271
- "transitive_dependencies": []
272
- }
37
+ rspec_junit_formatter,
38
+ sqlite
273
39
  ]
274
40
  }
275
41
  end
@@ -278,6 +44,14 @@ describe RepoAnalyzer::BundlerStatsExtractor, repo_analyzer_extractor_helpers: t
278
44
  allow(extractor).to receive(:`).with(
279
45
  'bundle exec bundle-stats stats -f json'
280
46
  ).and_return(stats.to_json)
47
+
48
+ allow(extractor).to receive(:`).with(
49
+ "bundle exec bundle-stats show 'rspec_junit_formatter' -f json"
50
+ ).and_return(rspec_junit_formatter.to_json)
51
+
52
+ allow(extractor).to receive(:`).with(
53
+ "bundle exec bundle-stats show 'sqlite' -f json"
54
+ ).and_return(sqlite.to_json)
281
55
  end
282
56
 
283
57
  it { expect(extract[:bundler_stats_extractor]).to eq(stats.with_indifferent_access) }
@@ -2,6 +2,7 @@ require 'rails_helper'
2
2
 
3
3
  describe RepoAnalyzer::ExtractProjectInfoJob, type: :job do
4
4
  let(:repo_name) { "platanus/alisur-formulator" }
5
+ let(:project_path) { "spec/assets/test_project" }
5
6
 
6
7
  let(:files_list) do
7
8
  "app/extractors/repo_analyzer/project_versions_extractor.rb"
@@ -31,7 +32,7 @@ describe RepoAnalyzer::ExtractProjectInfoJob, type: :job do
31
32
  let(:engine_root) { instance_double("Pathname", join: files_list) }
32
33
 
33
34
  def perform_now
34
- described_class.perform_now(repo_name)
35
+ described_class.perform_now(repo_name, project_path)
35
36
  end
36
37
 
37
38
  before do
@@ -44,7 +45,7 @@ describe RepoAnalyzer::ExtractProjectInfoJob, type: :job do
44
45
 
45
46
  it do
46
47
  perform_now
47
- expect(RepoAnalyzer::ProjectDataBridge).to have_received(:new).with(repo_name).once
48
+ expect(RepoAnalyzer::ProjectDataBridge).to have_received(:new).with(repo_name, project_path).once
48
49
  expect(RepoAnalyzer::ProjectVersionsExtractor).to have_received(:new).with(bridge).once
49
50
  end
50
51
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: repo_analyzer
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.4.0
4
+ version: 1.6.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Platanus
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: exe
11
11
  cert_chain: []
12
- date: 2023-05-30 00:00:00.000000000 Z
12
+ date: 2023-06-21 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: bundler-audit
@@ -350,7 +350,6 @@ files:
350
350
  - app/extractors/repo_analyzer/bundler_audit_extractor.rb
351
351
  - app/extractors/repo_analyzer/bundler_stats_extractor.rb
352
352
  - app/extractors/repo_analyzer/circleci_extractor.rb
353
- - app/extractors/repo_analyzer/fasterer_extractor.rb
354
353
  - app/extractors/repo_analyzer/github_extractor.rb
355
354
  - app/extractors/repo_analyzer/power_types_extractor.rb
356
355
  - app/extractors/repo_analyzer/project_config_extractor.rb
@@ -448,7 +447,6 @@ files:
448
447
  - spec/extractors/bundler_audit_extractor_spec.rb
449
448
  - spec/extractors/bundler_stats_extractor_spec.rb
450
449
  - spec/extractors/circleci_extractor_spec.rb
451
- - spec/extractors/fasterer_extractor_spec.rb
452
450
  - spec/extractors/github_extractor_spec.rb
453
451
  - spec/extractors/power_types_extractor_spec.rb
454
452
  - spec/extractors/project_config_extractor_spec.rb
@@ -556,7 +554,6 @@ test_files:
556
554
  - spec/extractors/bundler_audit_extractor_spec.rb
557
555
  - spec/extractors/bundler_stats_extractor_spec.rb
558
556
  - spec/extractors/circleci_extractor_spec.rb
559
- - spec/extractors/fasterer_extractor_spec.rb
560
557
  - spec/extractors/github_extractor_spec.rb
561
558
  - spec/extractors/power_types_extractor_spec.rb
562
559
  - spec/extractors/project_config_extractor_spec.rb
@@ -1,34 +0,0 @@
1
- require "fasterer/file_traverser"
2
-
3
- module RepoAnalyzer
4
- class FastererExtractor < ProjectInfoExtractor
5
- private
6
-
7
- def extracted_info
8
- { speedups: fasterer_info }
9
- end
10
-
11
- def fasterer_info
12
- @fasterer_info ||= fasterer_text.split("\n").inject([]) do |memo, row|
13
- next memo if row.blank?
14
-
15
- row_parts = row.split("\e")
16
- file_path_and_line = row_parts.second.gsub('[0;31;49m', '')
17
- file_path, line = file_path_and_line.split(':')
18
- next memo if file_path.include?("files inspected")
19
-
20
- message = row_parts.last.gsub('[0m ', '')
21
- memo << {
22
- file_path: file_path,
23
- line: line,
24
- message: message
25
- }
26
- end
27
- end
28
-
29
- def fasterer_text
30
- file_traverser = Fasterer::FileTraverser.new(".")
31
- OutputUtils.with_captured_stdout { file_traverser.traverse }
32
- end
33
- end
34
- end
@@ -1,45 +0,0 @@
1
- require 'rails_helper'
2
-
3
- describe RepoAnalyzer::FastererExtractor, repo_analyzer_extractor_helpers: true do
4
- describe "#extract" do
5
- let(:fasterer_result_content) do
6
- <<~TEXT
7
- \e[0;31;49mapp/extractors/repo_analyzer/github_extractor.rb:60\e[0m Don't rescue NoMethodError, rather check with respond_to?.
8
-
9
- \e[0;31;49mapp/jobs/repo_analyzer/extract_project_info_job.rb:17\e[0m Calling blocks with call is slower than yielding.
10
-
11
- \e[0;31;49mspec/dummy/config/puma.rb:14\e[0m Hash#fetch with second argument is slower than Hash#fetch with block.
12
-
13
- \e[0;32;49m75 files inspected\e[0m, \e[0;31;49m3 offenses detected\e[0m
14
- TEXT
15
- end
16
-
17
- before do
18
- allow(OutputUtils).to receive(:with_captured_stdout).and_return(fasterer_result_content)
19
- end
20
-
21
- let(:expected) do
22
- {
23
- speedups: [
24
- {
25
- file_path: "app/extractors/repo_analyzer/github_extractor.rb",
26
- line: "60",
27
- message: "Don't rescue NoMethodError, rather check with respond_to?."
28
- },
29
- {
30
- file_path: "app/jobs/repo_analyzer/extract_project_info_job.rb",
31
- line: "17",
32
- message: "Calling blocks with call is slower than yielding."
33
- },
34
- {
35
- file_path: "spec/dummy/config/puma.rb",
36
- line: "14",
37
- message: "Hash#fetch with second argument is slower than Hash#fetch with block."
38
- }
39
- ]
40
- }.with_indifferent_access
41
- end
42
-
43
- it { expect(extract[:fasterer_extractor]).to eq(expected) }
44
- end
45
- end