license_finder 1.0.0.1 → 1.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (30) hide show
  1. data/CHANGELOG.rdoc +21 -1
  2. data/features/configure_ignore_dependencies.feature +16 -0
  3. data/features/step_definitions/cli_steps.rb +1 -1
  4. data/features/step_definitions/configure_ignore_dependencies.rb +35 -0
  5. data/files/license_finder.yml +2 -0
  6. data/lib/license_finder/cli.rb +72 -30
  7. data/lib/license_finder/configuration.rb +17 -1
  8. data/lib/license_finder/dependency_manager.rb +11 -4
  9. data/lib/license_finder/package.rb +28 -18
  10. data/lib/license_finder/reports/reporter.rb +1 -1
  11. data/lib/license_finder/tables/dependency.rb +8 -1
  12. data/lib/templates/html_report.erb +2 -2
  13. data/license_finder.gemspec +2 -2
  14. data/readme.md +17 -13
  15. data/spec/lib/license_finder/cli_spec.rb +46 -4
  16. data/spec/lib/license_finder/configuration_spec.rb +52 -0
  17. data/spec/lib/license_finder/dependency_manager_spec.rb +25 -9
  18. data/spec/lib/license_finder/package_managers/bower_package_spec.rb +2 -2
  19. data/spec/lib/license_finder/package_managers/bundler_package_spec.rb +13 -9
  20. data/spec/lib/license_finder/package_managers/gradle_package_spec.rb +1 -1
  21. data/spec/lib/license_finder/package_managers/maven_package_spec.rb +1 -1
  22. data/spec/lib/license_finder/package_managers/npm_package_spec.rb +2 -2
  23. data/spec/lib/license_finder/package_managers/pip_package_spec.rb +1 -1
  24. data/spec/lib/license_finder/reports/html_report_spec.rb +6 -5
  25. data/spec/lib/license_finder/reports/reporter_spec.rb +1 -1
  26. data/spec/lib/license_finder/tables/dependency_spec.rb +14 -1
  27. data/spec/support/stdout_helpers.rb +25 -0
  28. metadata +82 -47
  29. checksums.yaml +0 -7
  30. data/spec/support/silence_stdout.rb +0 -13
@@ -0,0 +1,25 @@
1
+ module StdoutHelpers
2
+ def silence_stdout
3
+ orig_stdout = $stdout
4
+ $stdout = File.open("/dev/null", "w")
5
+ yield
6
+ ensure
7
+ $stdout = orig_stdout
8
+ end
9
+
10
+ def capture_stdout
11
+ orig_stdout = $stdout
12
+ stdout_reader, $stdout = IO.pipe
13
+
14
+ yield
15
+
16
+ $stdout.close
17
+ stdout_reader.read
18
+ ensure
19
+ $stdout = orig_stdout
20
+ end
21
+ end
22
+
23
+ RSpec.configure do |c|
24
+ c.include(StdoutHelpers)
25
+ end
metadata CHANGED
@@ -1,7 +1,8 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: license_finder
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.0.1
4
+ version: 1.0.1
5
+ prerelease:
5
6
  platform: ruby
6
7
  authors:
7
8
  - Jacob Maine
@@ -13,213 +14,242 @@ authors:
13
14
  - Trevor John
14
15
  - David Tengdin
15
16
  - William Ramsey
17
+ - David Dening
16
18
  autorequire:
17
19
  bindir: bin
18
20
  cert_chain: []
19
- date: 2014-05-23 00:00:00.000000000 Z
21
+ date: 2014-05-28 00:00:00.000000000 Z
20
22
  dependencies:
21
23
  - !ruby/object:Gem::Dependency
22
24
  name: bundler
23
25
  requirement: !ruby/object:Gem::Requirement
26
+ none: false
24
27
  requirements:
25
- - - ">="
28
+ - - ! '>='
26
29
  - !ruby/object:Gem::Version
27
30
  version: '0'
28
31
  type: :runtime
29
32
  prerelease: false
30
33
  version_requirements: !ruby/object:Gem::Requirement
34
+ none: false
31
35
  requirements:
32
- - - ">="
36
+ - - ! '>='
33
37
  - !ruby/object:Gem::Version
34
38
  version: '0'
35
39
  - !ruby/object:Gem::Dependency
36
40
  name: sequel
37
41
  requirement: !ruby/object:Gem::Requirement
42
+ none: false
38
43
  requirements:
39
- - - ">="
44
+ - - ! '>='
40
45
  - !ruby/object:Gem::Version
41
46
  version: '0'
42
47
  type: :runtime
43
48
  prerelease: false
44
49
  version_requirements: !ruby/object:Gem::Requirement
50
+ none: false
45
51
  requirements:
46
- - - ">="
52
+ - - ! '>='
47
53
  - !ruby/object:Gem::Version
48
54
  version: '0'
49
55
  - !ruby/object:Gem::Dependency
50
56
  name: thor
51
57
  requirement: !ruby/object:Gem::Requirement
58
+ none: false
52
59
  requirements:
53
- - - ">="
60
+ - - ! '>='
54
61
  - !ruby/object:Gem::Version
55
62
  version: '0'
56
63
  type: :runtime
57
64
  prerelease: false
58
65
  version_requirements: !ruby/object:Gem::Requirement
66
+ none: false
59
67
  requirements:
60
- - - ">="
68
+ - - ! '>='
61
69
  - !ruby/object:Gem::Version
62
70
  version: '0'
63
71
  - !ruby/object:Gem::Dependency
64
72
  name: httparty
65
73
  requirement: !ruby/object:Gem::Requirement
74
+ none: false
66
75
  requirements:
67
- - - ">="
76
+ - - ! '>='
68
77
  - !ruby/object:Gem::Version
69
78
  version: '0'
70
79
  type: :runtime
71
80
  prerelease: false
72
81
  version_requirements: !ruby/object:Gem::Requirement
82
+ none: false
73
83
  requirements:
74
- - - ">="
84
+ - - ! '>='
75
85
  - !ruby/object:Gem::Version
76
86
  version: '0'
77
87
  - !ruby/object:Gem::Dependency
78
88
  name: xml-simple
79
89
  requirement: !ruby/object:Gem::Requirement
90
+ none: false
80
91
  requirements:
81
- - - ">="
92
+ - - ! '>='
82
93
  - !ruby/object:Gem::Version
83
94
  version: '0'
84
95
  type: :runtime
85
96
  prerelease: false
86
97
  version_requirements: !ruby/object:Gem::Requirement
98
+ none: false
87
99
  requirements:
88
- - - ">="
100
+ - - ! '>='
89
101
  - !ruby/object:Gem::Version
90
102
  version: '0'
91
103
  - !ruby/object:Gem::Dependency
92
104
  name: sqlite3
93
105
  requirement: !ruby/object:Gem::Requirement
106
+ none: false
94
107
  requirements:
95
- - - ">="
108
+ - - ! '>='
96
109
  - !ruby/object:Gem::Version
97
110
  version: '0'
98
111
  type: :runtime
99
112
  prerelease: false
100
113
  version_requirements: !ruby/object:Gem::Requirement
114
+ none: false
101
115
  requirements:
102
- - - ">="
116
+ - - ! '>='
103
117
  - !ruby/object:Gem::Version
104
118
  version: '0'
105
119
  - !ruby/object:Gem::Dependency
106
120
  name: rake
107
121
  requirement: !ruby/object:Gem::Requirement
122
+ none: false
108
123
  requirements:
109
- - - ">="
124
+ - - ! '>='
110
125
  - !ruby/object:Gem::Version
111
126
  version: '0'
112
127
  type: :development
113
128
  prerelease: false
114
129
  version_requirements: !ruby/object:Gem::Requirement
130
+ none: false
115
131
  requirements:
116
- - - ">="
132
+ - - ! '>='
117
133
  - !ruby/object:Gem::Version
118
134
  version: '0'
119
135
  - !ruby/object:Gem::Dependency
120
136
  name: rspec
121
137
  requirement: !ruby/object:Gem::Requirement
138
+ none: false
122
139
  requirements:
123
- - - ">="
140
+ - - ! '>='
124
141
  - !ruby/object:Gem::Version
125
142
  version: '0'
126
143
  type: :development
127
144
  prerelease: false
128
145
  version_requirements: !ruby/object:Gem::Requirement
146
+ none: false
129
147
  requirements:
130
- - - ">="
148
+ - - ! '>='
131
149
  - !ruby/object:Gem::Version
132
150
  version: '0'
133
151
  - !ruby/object:Gem::Dependency
134
152
  name: xpath
135
153
  requirement: !ruby/object:Gem::Requirement
154
+ none: false
136
155
  requirements:
137
- - - ">="
156
+ - - ! '>='
138
157
  - !ruby/object:Gem::Version
139
158
  version: '0'
140
159
  type: :development
141
160
  prerelease: false
142
161
  version_requirements: !ruby/object:Gem::Requirement
162
+ none: false
143
163
  requirements:
144
- - - ">="
164
+ - - ! '>='
145
165
  - !ruby/object:Gem::Version
146
166
  version: '0'
147
167
  - !ruby/object:Gem::Dependency
148
168
  name: cucumber
149
169
  requirement: !ruby/object:Gem::Requirement
170
+ none: false
150
171
  requirements:
151
- - - ">="
172
+ - - ! '>='
152
173
  - !ruby/object:Gem::Version
153
174
  version: '0'
154
175
  type: :development
155
176
  prerelease: false
156
177
  version_requirements: !ruby/object:Gem::Requirement
178
+ none: false
157
179
  requirements:
158
- - - ">="
180
+ - - ! '>='
159
181
  - !ruby/object:Gem::Version
160
182
  version: '0'
161
183
  - !ruby/object:Gem::Dependency
162
184
  name: pry
163
185
  requirement: !ruby/object:Gem::Requirement
186
+ none: false
164
187
  requirements:
165
- - - ">="
188
+ - - ! '>='
166
189
  - !ruby/object:Gem::Version
167
190
  version: '0'
168
191
  type: :development
169
192
  prerelease: false
170
193
  version_requirements: !ruby/object:Gem::Requirement
194
+ none: false
171
195
  requirements:
172
- - - ">="
196
+ - - ! '>='
173
197
  - !ruby/object:Gem::Version
174
198
  version: '0'
175
199
  - !ruby/object:Gem::Dependency
176
200
  name: capybara
177
201
  requirement: !ruby/object:Gem::Requirement
202
+ none: false
178
203
  requirements:
179
- - - "~>"
204
+ - - ~>
180
205
  - !ruby/object:Gem::Version
181
206
  version: 2.0.0
182
207
  type: :development
183
208
  prerelease: false
184
209
  version_requirements: !ruby/object:Gem::Requirement
210
+ none: false
185
211
  requirements:
186
- - - "~>"
212
+ - - ~>
187
213
  - !ruby/object:Gem::Version
188
214
  version: 2.0.0
189
215
  - !ruby/object:Gem::Dependency
190
216
  name: webmock
191
217
  requirement: !ruby/object:Gem::Requirement
218
+ none: false
192
219
  requirements:
193
- - - "~>"
220
+ - - ~>
194
221
  - !ruby/object:Gem::Version
195
222
  version: '1.13'
196
223
  type: :development
197
224
  prerelease: false
198
225
  version_requirements: !ruby/object:Gem::Requirement
226
+ none: false
199
227
  requirements:
200
- - - "~>"
228
+ - - ~>
201
229
  - !ruby/object:Gem::Version
202
230
  version: '1.13'
203
231
  - !ruby/object:Gem::Dependency
204
232
  name: cocoapods
205
233
  requirement: !ruby/object:Gem::Requirement
234
+ none: false
206
235
  requirements:
207
- - - ">="
236
+ - - ! '>='
208
237
  - !ruby/object:Gem::Version
209
238
  version: '0'
210
239
  type: :development
211
240
  prerelease: false
212
241
  version_requirements: !ruby/object:Gem::Requirement
242
+ none: false
213
243
  requirements:
214
- - - ">="
244
+ - - ! '>='
215
245
  - !ruby/object:Gem::Version
216
246
  version: '0'
217
- description: |2
218
- Do you know the licenses of all your application's dependencies? What open source software licenses will your business accept?
219
-
220
- LicenseFinder culls your package managers, detects the licenses of the packages in them, and gives you a report that you can act on. If you already know
221
- what licenses your business is comfortable with, you can whitelist them, leaving you with an action report of only those dependencies that have
222
- licenses that fall outside of the whitelist.
247
+ description: ! " Do you know the licenses of all your application's dependencies?
248
+ What open source software licenses will your business accept?\n\n LicenseFinder
249
+ culls your package managers, detects the licenses of the packages in them, and gives
250
+ you a report that you can act on. If you already know\n what licenses your business
251
+ is comfortable with, you can whitelist them, leaving you with an action report of
252
+ only those dependencies that have\n licenses that fall outside of the whitelist.\n"
223
253
  email:
224
254
  - commoncode@pivotalabs.com
225
255
  executables:
@@ -227,10 +257,10 @@ executables:
227
257
  extensions: []
228
258
  extra_rdoc_files: []
229
259
  files:
230
- - ".force-build"
231
- - ".gitignore"
232
- - ".rspec"
233
- - ".travis.yml"
260
+ - .force-build
261
+ - .gitignore
262
+ - .rspec
263
+ - .travis.yml
234
264
  - CHANGELOG.rdoc
235
265
  - Gemfile
236
266
  - LICENSE
@@ -261,6 +291,7 @@ files:
261
291
  - features/cli.feature
262
292
  - features/cocoapods_dependencies.feature
263
293
  - features/configure_bundler_groups.feature
294
+ - features/configure_ignore_dependencies.feature
264
295
  - features/configure_project_name.feature
265
296
  - features/configure_whitelist.feature
266
297
  - features/gradle_dependencies.feature
@@ -275,6 +306,7 @@ files:
275
306
  - features/step_definitions/cli_steps.rb
276
307
  - features/step_definitions/cocoapod_steps.rb
277
308
  - features/step_definitions/configure_bundler_groups_steps.rb
309
+ - features/step_definitions/configure_ignore_dependencies.rb
278
310
  - features/step_definitions/configure_project_name_steps.rb
279
311
  - features/step_definitions/configure_whitelist_steps.rb
280
312
  - features/step_definitions/gradle_steps.rb
@@ -410,35 +442,37 @@ files:
410
442
  - spec/lib/license_finder/yml_to_sql_spec.rb
411
443
  - spec/lib/license_finder_spec.rb
412
444
  - spec/spec_helper.rb
413
- - spec/support/silence_stdout.rb
445
+ - spec/support/stdout_helpers.rb
414
446
  homepage: https://github.com/pivotal/LicenseFinder
415
447
  licenses:
416
448
  - MIT
417
- metadata: {}
418
449
  post_install_message:
419
450
  rdoc_options: []
420
451
  require_paths:
421
452
  - lib
422
453
  required_ruby_version: !ruby/object:Gem::Requirement
454
+ none: false
423
455
  requirements:
424
- - - ">="
456
+ - - ! '>='
425
457
  - !ruby/object:Gem::Version
426
458
  version: 1.9.3
427
459
  required_rubygems_version: !ruby/object:Gem::Requirement
460
+ none: false
428
461
  requirements:
429
- - - ">="
462
+ - - ! '>='
430
463
  - !ruby/object:Gem::Version
431
464
  version: '0'
432
465
  requirements: []
433
466
  rubyforge_project:
434
- rubygems_version: 2.2.2
467
+ rubygems_version: 1.8.27
435
468
  signing_key:
436
- specification_version: 4
469
+ specification_version: 3
437
470
  summary: Audit the OSS licenses of your application's dependencies.
438
471
  test_files:
439
472
  - features/cli.feature
440
473
  - features/cocoapods_dependencies.feature
441
474
  - features/configure_bundler_groups.feature
475
+ - features/configure_ignore_dependencies.feature
442
476
  - features/configure_project_name.feature
443
477
  - features/configure_whitelist.feature
444
478
  - features/gradle_dependencies.feature
@@ -453,6 +487,7 @@ test_files:
453
487
  - features/step_definitions/cli_steps.rb
454
488
  - features/step_definitions/cocoapod_steps.rb
455
489
  - features/step_definitions/configure_bundler_groups_steps.rb
490
+ - features/step_definitions/configure_ignore_dependencies.rb
456
491
  - features/step_definitions/configure_project_name_steps.rb
457
492
  - features/step_definitions/configure_whitelist_steps.rb
458
493
  - features/step_definitions/gradle_steps.rb
@@ -524,4 +559,4 @@ test_files:
524
559
  - spec/lib/license_finder/yml_to_sql_spec.rb
525
560
  - spec/lib/license_finder_spec.rb
526
561
  - spec/spec_helper.rb
527
- - spec/support/silence_stdout.rb
562
+ - spec/support/stdout_helpers.rb
checksums.yaml DELETED
@@ -1,7 +0,0 @@
1
- ---
2
- SHA1:
3
- metadata.gz: 5bbf7aeafa8919a1c7c8e45e2c3d2995c320d57d
4
- data.tar.gz: 7794d4ce07d5c799b64a9cf1026be7ccb3fab14b
5
- SHA512:
6
- metadata.gz: 3c9ca00f2ce1047e0bf25953975b0fb1738059b5e479533286d201e840d56042e319745649ea530c6d0f841d097aace3310e8d5f000344b75043268d02430225
7
- data.tar.gz: 62e488ad2e0152fb937d5340dfec376eeba1cfd5d39bb90eeacc3167aa5ccf25af9fe1a93b18cfb276ee6c881dc8d4741bdfdb3830563e3a539fdf144bf6db70
@@ -1,13 +0,0 @@
1
- module SilenceStdout
2
- def silence_stdout
3
- orig_stdout = $stdout
4
- $stdout = File.open("/dev/null", "w")
5
- yield
6
- ensure
7
- $stdout = orig_stdout
8
- end
9
- end
10
-
11
- RSpec.configure do |c|
12
- c.include(SilenceStdout)
13
- end