spdx 2.0.12 → 4.0.1

Sign up to get free protection for your applications and to get access to all the features.
data/spdx.gemspec CHANGED
@@ -9,7 +9,7 @@ Gem::Specification.new do |spec|
9
9
  spec.version = Spdx::VERSION
10
10
  spec.authors = ["Tidelift, Inc."]
11
11
  spec.email = ["support@tidelift.com"]
12
- spec.summary = "A SPDX license normalizer"
12
+ spec.summary = "A SPDX license parser"
13
13
  spec.homepage = "https://github.com/librariesio/spdx"
14
14
  spec.license = "MIT"
15
15
 
@@ -18,7 +18,6 @@ Gem::Specification.new do |spec|
18
18
  spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
19
19
  spec.require_paths = ["lib"]
20
20
 
21
- spec.add_dependency "fuzzy_match", "~> 2.1"
22
21
  spec.add_dependency "treetop", "~> 1.6"
23
22
  spec.add_development_dependency "bundler"
24
23
  spec.add_development_dependency "pry"
data/spec/spdx_spec.rb CHANGED
@@ -3,229 +3,144 @@
3
3
  require "spec_helper"
4
4
 
5
5
  describe Spdx do
6
- describe "find" do
7
- it "should return know license from short code" do
8
- expect(Spdx.find("Apache-2.0").name).to eq("Apache License 2.0")
9
- end
10
-
11
- it "should work with case-insentive short codes" do
12
- expect(Spdx.find("apache-2.0").name).to eq("Apache License 2.0")
13
- expect(Spdx.find("agpl-3.0").name).to eq("GNU Affero General Public License v3.0")
14
- end
15
-
16
- it "should return know license from full name" do
17
- expect(Spdx.find("Apache License 2.0").name).to eq("Apache License 2.0")
18
- end
19
-
20
- it "should return nil for commercial" do
21
- expect(Spdx.find("Commercial")).to be_nil
22
- end
23
-
24
- it "should return nil for garbage" do
25
- expect(Spdx.find("foo bar baz")).to be_nil
26
- expect(Spdx.find("https://github.com/AuthorizeNet/sdk-ruby/blob/master/license.txt")).to be_nil
27
- end
28
-
29
- it "should return know license from an alias" do
30
- expect(Spdx.find("The Apache Software License, Version 2.0").name).to eq("Apache License 2.0")
31
- expect(Spdx.find("Apache2").name).to eq("Apache License 2.0")
32
- expect(Spdx.find("Apache License, Version 2.0").name).to eq("Apache License 2.0")
33
- expect(Spdx.find("Educational Community License, Version 2.0").name).to eq("Educational Community License v2.0")
34
- expect(Spdx.find("CDDL + GPLv2 with classpath exception").name).to \
35
- eq("GNU General Public License v2.0 w/Classpath exception")
36
- expect(Spdx.find("The MIT License").name).to eq("MIT License")
37
- expect(Spdx.find("UNLICENSE").name).to eq("The Unlicense")
38
- end
39
-
40
- it "should strip whitespace from strings before lookups" do
41
- expect(Spdx.find(" BSD-3-Clause").id).to eq("BSD-3-Clause")
42
- end
43
-
44
- it "should handle pypi classifiers properly" do
45
- pypi_mappings = [
46
- ["Aladdin Free Public License (AFPL)", "Aladdin"],
47
- ["CC0 1.0 Universal (CC0 1.0) Public Domain Dedication", "CC0-1.0"],
48
- ["CeCILL-B Free Software License Agreement (CECILL-B)", "CECILL-B"],
49
- ["CeCILL-C Free Software License Agreement (CECILL-C)", "CECILL-C"],
50
- ["Eiffel Forum License (EFL)", "EFL-2.0"],
51
- ["Netscape Public License (NPL)", "NPL-1.1"],
52
- ["Nokia Open Source License (NOKOS)", "Nokia"],
53
- ["Academic Free License (AFL)", "AFL-3.0"],
54
- ["Apache Software License", "Apache-2.0"],
55
- ["Apple Public Source License", "APSL-2.0"],
56
- ["Artistic License", "Artistic-2.0"],
57
- ["Attribution Assurance License", "AAL"],
58
- ["Boost Software License 1.0 (BSL-1.0)", "BSL-1.0"],
59
- ["BSD License", "BSD-3-Clause"],
60
- ["Common Development and Distribution License 1.0 (CDDL-1.0)", "CDDL-1.0"],
61
- ["Common Public License", "CPL-1.0"],
62
- ["Eclipse Public License 1.0 (EPL-1.0)", "EPL-1.0"],
63
- ["Eclipse Public License 2.0 (EPL-2.0)", "EPL-2.0"],
64
- ["Eiffel Forum License", "EFL-2.0"],
65
- ["European Union Public Licence 1.0 (EUPL 1.0)", "EUPL-1.0"],
66
- ["European Union Public Licence 1.1 (EUPL 1.1)", "EUPL-1.1"],
67
- ["European Union Public Licence 1.2 (EUPL 1.2)", "EUPL-1.2"],
68
- ["GNU Affero General Public License v3", "AGPL-3.0"],
69
- ["GNU Affero General Public License v3 or later (AGPLv3+)", "AGPL-3.0-or-later"],
70
- ["GNU Free Documentation License (FDL)", "GFDL-1.3"],
71
- ["GNU General Public License (GPL)", "GPL-2.0+"],
72
- ["GNU General Public License v2 (GPLv2)", "GPL-2.0"],
73
- ["GNU General Public License v2 or later (GPLv2+)", "GPL-2.0+"],
74
- ["GNU General Public License v3 (GPLv3)", "GPL-3.0"],
75
- ["GNU General Public License v3 or later (GPLv3+)", "GPL-3.0+"],
76
- ["GNU Lesser General Public License v2 (LGPLv2)", "LGPL-2.0"],
77
- ["GNU Lesser General Public License v2 or later (LGPLv2+)", "LGPL-2.0+"],
78
- ["GNU Lesser General Public License v3 (LGPLv3)", "LGPL-3.0"],
79
- ["GNU Lesser General Public License v3 or later (LGPLv3+)", "LGPL-3.0+"],
80
- ["GNU Library or Lesser General Public License (LGPL)", "LGPL-2.0+"],
81
- ["IBM Public License", "IPL-1.0"],
82
- ["Intel Open Source License", "Intel"],
83
- ["ISC License (ISCL)", "ISC"],
84
- # ['MirOS License (MirOS)', 'MirOS'],
85
- ["MIT License", "MIT"],
86
- ["Motosoto License", "Motosoto"],
87
- ["Mozilla Public License 1.0 (MPL)", "MPL-1.0"],
88
- ["Mozilla Public License 1.1 (MPL 1.1)", "MPL-1.1"],
89
- ["Mozilla Public License 2.0 (MPL 2.0)", "MPL-2.0"],
90
- ["Nethack General Public License", "NGPL"],
91
- ["Nokia Open Source License", "Nokia"],
92
- ["Open Group Test Suite License", "OGTSL"],
93
- ["PostgreSQL License", "PostgreSQL"],
94
- ["Python License (CNRI Python License)", "CNRI-Python"],
95
- # ['Python Software Foundation License', 'Python-2.0'],
96
- ["Qt Public License (QPL)", "QPL-1.0"],
97
- ["Ricoh Source Code Public License", "RSCPL"],
98
- ["SIL Open Font License 1.1 (OFL-1.1)", "OFL-1.1"],
99
- ["Sleepycat License", "Sleepycat"],
100
- ["Sun Industry Standards Source License (SISSL)", "SISSL-1.2"],
101
- ["Sun Public License", "SPL-1.0"],
102
- ["Universal Permissive License (UPL)", "UPL-1.0"],
103
- ["University of Illinois/NCSA Open Source License", "NCSA"],
104
- ["Vovida Software License 1.0", "VSL-1.0"],
105
- ["W3C License", "W3C"],
106
- ["X.Net License", "Xnet"],
107
- ["zlib/libpng License", "zlib-acknowledgement"],
108
- ["Zope Public License", "ZPL-2.1"],
109
- ]
110
- pypi_mappings.each do |license, mapped|
111
- expect(Spdx.find(license).id).to eq(mapped)
6
+ context "spdx parsing" do
7
+ context "parse" do
8
+ it "handles bad input" do
9
+ expect { Spdx.parse(nil) }.to raise_error(SpdxGrammar::SpdxParseError)
10
+ expect { Spdx.parse("") }.to raise_error(SpdxGrammar::SpdxParseError)
11
+ end
12
+ it "parses into respective classes" do
13
+ expect(Spdx.parse("MIT")).to be_an_instance_of(SpdxGrammar::License)
14
+ expect(Spdx.parse("MIT AND Apache-2.0")).to be_an_instance_of(SpdxGrammar::LogicalAnd)
15
+ expect(Spdx.parse("(MIT AND Apache-2.0)")).to be_an_instance_of(SpdxGrammar::LogicalAnd)
16
+ expect(Spdx.parse("MIT OR Apache-2.0")).to be_an_instance_of(SpdxGrammar::LogicalOr)
17
+ expect(Spdx.parse("MIT AND Apache-2.0").left).to be_an_instance_of(SpdxGrammar::License)
18
+ expect(Spdx.parse("MIT AND Apache-2.0").right).to be_an_instance_of(SpdxGrammar::License)
19
+ expect(Spdx.parse("MIT+")).to be_an_instance_of(SpdxGrammar::LicensePlus)
20
+ expect(Spdx.parse("LicenseRef-MIT-style-1")).to be_an_instance_of(SpdxGrammar::LicenseRef)
21
+ expect(Spdx.parse("DocumentRef-something-1:LicenseRef-MIT-style-1")).to be_an_instance_of(SpdxGrammar::DocumentRef)
22
+ expect(Spdx.parse("GPL-2.0-only WITH Classpath-exception-2.0")).to be_an_instance_of(SpdxGrammar::With)
23
+ expect(Spdx.parse("GPL-2.0-only WITH Classpath-exception-2.0").license).to be_an_instance_of(SpdxGrammar::License)
24
+ expect(Spdx.parse("GPL-2.0-only WITH Classpath-exception-2.0").exception).to be_an_instance_of(SpdxGrammar::LicenseException)
25
+ expect(Spdx.parse("NONE")).to be_an_instance_of(SpdxGrammar::None)
26
+ expect(Spdx.parse("NOASSERTION")).to be_an_instance_of(SpdxGrammar::NoAssertion)
112
27
  end
113
28
  end
114
-
115
- it "should return know licenses for special cases" do
116
- expect(Spdx.find("MPL1").name).to eq("Mozilla Public License 1.0")
117
- expect(Spdx.find("MPL1.0").name).to eq("Mozilla Public License 1.0")
118
- expect(Spdx.find("MPL1.1").name).to eq("Mozilla Public License 1.1")
119
- expect(Spdx.find("MPL2").name).to eq("Mozilla Public License 2.0")
120
- expect(Spdx.find("MPL2.0").name).to eq("Mozilla Public License 2.0")
121
- expect(Spdx.find("GPL3").name).to eq("GNU General Public License v3.0 only")
122
- expect(Spdx.find("GPL v3").name).to eq("GNU General Public License v3.0 only")
123
- expect(Spdx.find("GPL3").name).to eq("GNU General Public License v3.0 only")
124
- expect(Spdx.find("GPL 3.0").name).to eq("GNU General Public License v3.0 only")
125
- expect(Spdx.find("GPL-3").name).to eq("GNU General Public License v3.0 only")
126
- expect(Spdx.find("GPL-2 | GPL-3 [expanded from: GPL (≥ 2)]").name).to \
127
- eq("GNU General Public License v2.0 or later")
128
- expect(Spdx.find("GPL-2 | GPL-3 [expanded from: GPL]").name).to \
129
- eq("GNU General Public License v2.0 or later")
130
- expect(Spdx.find("GPL (≥ 3)").name).to eq("GNU General Public License v3.0 or later")
131
- expect(Spdx.find("gpl30").name).to eq("GNU General Public License v3.0 only")
132
- expect(Spdx.find("GPL v2+").name).to eq("GNU General Public License v2.0 or later")
133
- expect(Spdx.find("GPL 2").name).to eq("GNU General Public License v2.0 only")
134
- expect(Spdx.find("GPL v2").name).to eq("GNU General Public License v2.0 only")
135
- expect(Spdx.find("GPL2").name).to eq("GNU General Public License v2.0 only")
136
- expect(Spdx.find("GPL-2 | GPL-3").name).to eq("GNU General Public License v2.0 or later")
137
- expect(Spdx.find("GPL-2 | GPL-3 [expanded from: GPL (≥ 2.0)]").name).to \
138
- eq("GNU General Public License v2.0 or later")
139
- expect(Spdx.find("GPL2 w/ CPE").name).to eq("GNU General Public License v2.0 w/Classpath exception")
140
- expect(Spdx.find("GPL 2.0").name).to eq("GNU General Public License v2.0 only")
141
- expect(Spdx.find("New BSD License (GPL-compatible)").name).to eq('BSD 3-Clause "New" or "Revised" License')
142
- expect(Spdx.find("The GPL V3").name).to eq("GNU General Public License v3.0 only")
143
- expect(Spdx.find("perl_5").name).to eq("Artistic License 1.0 (Perl)")
144
- expect(Spdx.find("BSD3").name).to eq('BSD 3-Clause "New" or "Revised" License')
145
- expect(Spdx.find("BSD").name).to eq('BSD 3-Clause "New" or "Revised" License')
146
- expect(Spdx.find("GPLv3").name).to eq("GNU General Public License v3.0 only")
147
- expect(Spdx.find("LGPLv2 or later").name).to eq("GNU Library General Public License v2.1 or later")
148
- expect(Spdx.find("GPLv2 or later").name).to eq("GNU General Public License v2.0 or later")
149
- expect(Spdx.find("Public Domain").name).to eq("The Unlicense")
150
- expect(Spdx.find("GPL-2").name).to eq("GNU General Public License v2.0 only")
151
- expect(Spdx.find("GPL").name).to eq("GNU General Public License v2.0 or later")
152
- expect(Spdx.find("GNU LESSER GENERAL PUBLIC LICENSE").name).to \
153
- eq("GNU Library General Public License v2.1 or later")
154
- expect(Spdx.find("New BSD License").name).to eq('BSD 3-Clause "New" or "Revised" License')
155
- expect(Spdx.find("(MIT OR X11) ").name).to eq("MIT License")
156
- expect(Spdx.find("mit-license").name).to eq("MIT License")
157
- expect(Spdx.find("lgpl-3").name).to eq("GNU Lesser General Public License v3.0 only")
158
- expect(Spdx.find("agpl-3").name).to eq("GNU Affero General Public License v3.0")
159
- expect(Spdx.find("cc by-sa 4.0").name).to eq("Creative Commons Attribution Share Alike 4.0 International")
160
- expect(Spdx.find("cc by-nc-sa 3.0").name).to \
161
- eq("Creative Commons Attribution Non Commercial Share Alike 3.0 Unported")
162
- expect(Spdx.find("cc by-sa 3.0").name).to eq("Creative Commons Attribution Share Alike 3.0 Unported")
163
- expect(Spdx.find("gpl_1").name).to eq("GNU General Public License v1.0 only")
164
- expect(Spdx.find("gpl_2").name).to eq("GNU General Public License v2.0 only")
165
- expect(Spdx.find("gpl_3").name).to eq("GNU General Public License v3.0 only")
166
- expect(Spdx.find("artistic_2").name).to eq("Artistic License 2.0")
167
- expect(Spdx.find("artistic_1").name).to eq("Artistic License 1.0")
168
- expect(Spdx.find("apache_2_0").name).to eq("Apache License 2.0")
169
- expect(Spdx.find("apache_v2").name).to eq("Apache License 2.0")
170
- expect(Spdx.find("lgpl_2_1").name).to eq("GNU Lesser General Public License v2.1 only")
171
- expect(Spdx.find("lgpl_v2_1").name).to eq("GNU Lesser General Public License v2.1 only")
172
-
173
- expect(Spdx.find("BSD 3-Clause").name).to eq('BSD 3-Clause "New" or "Revised" License')
174
- expect(Spdx.find("BSD 3-Clause").name).to eq('BSD 3-Clause "New" or "Revised" License')
175
- expect(Spdx.find("BSD 2-Clause").name).to eq('BSD 2-Clause "Simplified" License')
176
- expect(Spdx.find("BSD 2-clause").name).to eq('BSD 2-Clause "Simplified" License')
177
- expect(Spdx.find("BSD Style").name).to eq('BSD 3-Clause "New" or "Revised" License')
178
-
179
- expect(Spdx.find("GNU LGPL v3+").name).to eq("GNU Lesser General Public License v3.0 only")
180
- expect(Spdx.find("ZPL 2.1").name).to eq("Zope Public License 2.1")
181
- end
182
- end
183
- context "spdx parsing" do
184
- context "valid_spdx?" do
29
+ context "valid?" do
185
30
  it "returns false for invalid spdx" do
186
- expect(Spdx.valid_spdx?("AND AND")).to be false
187
- expect(Spdx.valid_spdx?("MIT OR MIT AND OR")).to be false
188
- expect(Spdx.valid_spdx?("MIT OR FAKEYLICENSE")).to be false
189
- expect(Spdx.valid_spdx?(nil)).to be false
190
- expect(Spdx.valid_spdx?("")).to be false
191
- expect(Spdx.valid_spdx?("MIT (MIT)")).to be false
31
+ expect(Spdx.valid?("AND AND")).to be false
32
+ expect(Spdx.valid?(" AND ")).to be false
33
+ expect(Spdx.valid?(" WITH ")).to be false
34
+ expect(Spdx.valid?("MIT AND ")).to be false
35
+ expect(Spdx.valid?("MIT OR MIT AND OR")).to be false
36
+ expect(Spdx.valid?("MIT OR FAKEYLICENSE")).to be false
37
+ expect(Spdx.valid?(nil)).to be false
38
+ expect(Spdx.valid?("")).to be false
39
+ expect(Spdx.valid?("MIT (MIT)")).to be false
192
40
  end
193
41
  it "returns true for valid spdx" do
194
- expect(Spdx.valid_spdx?("(MIT OR MPL-2.0)")).to be true
195
- expect(Spdx.valid_spdx?("MIT")).to be true
196
- expect(Spdx.valid_spdx?("((MIT OR AGPL-1.0) AND (MIT OR MPL-2.0))")).to be true
197
- expect(Spdx.valid_spdx?("MIT OR (MIT)")).to be true
42
+ expect(Spdx.valid?("(MIT OR MPL-2.0)")).to be true
43
+ expect(Spdx.valid?("MIT")).to be true
44
+ expect(Spdx.valid?("MIT OR MPL-2.0 AND AGPL-1.0")).to be true
45
+ expect(Spdx.valid?("MIT OR (GPL-1.0 OR MPL-2.0) AND AGPL-1.0")).to be true
46
+ expect(Spdx.valid?("MIT AND MPL-2.0 OR AGPL-1.0")).to be true
47
+ expect(Spdx.valid?("MIT AND (GPL-1.0 OR MPL-2.0) OR AGPL-1.0")).to be true
48
+ expect(Spdx.valid?("MIT OR (DocumentRef-something-1:LicenseRef-MIT-style-1 OR MPL-2.0) AND AGPL-1.0")).to be true
49
+ expect(Spdx.valid?("((MIT OR AGPL-1.0) AND (MIT OR MPL-2.0))")).to be true
50
+ expect(Spdx.valid?("MIT OR (MIT)")).to be true
198
51
  end
199
52
  it "returns true for NONE and NOASSERTION" do
200
- expect(Spdx.valid_spdx?("NONE")).to be true
201
- expect(Spdx.valid_spdx?("(NONE)")).to be false
202
- expect(Spdx.valid_spdx?("NOASSERTION")).to be true
203
- expect(Spdx.valid_spdx?("MIT OR NONE")).to be false
53
+ expect(Spdx.valid?("NONE")).to be true
54
+ expect(Spdx.valid?("(NONE)")).to be false
55
+ expect(Spdx.valid?("NOASSERTION")).to be true
56
+ expect(Spdx.valid?("MIT OR NONE")).to be false
204
57
  end
205
58
  it "returns true for + expression" do
206
- expect(Spdx.valid_spdx?("AGPL-1.0+"))
59
+ expect(Spdx.valid?("AGPL-3.0+")).to be true
60
+ end
61
+ it "is case insentive for license ids" do
62
+ expect(Spdx.valid?("mit OR agpl-3.0+")).to be true
63
+ end
64
+ it "handles LicenseRef" do
65
+ expect(Spdx.valid?("MIT OR LicenseRef-MIT-style-1")).to be true
207
66
  end
67
+ it "handles DocumentRef" do
68
+ expect(Spdx.valid?("MIT OR DocumentRef-something-1:LicenseRef-MIT-style-1")).to be true
69
+ expect(Spdx.valid?("MIT OR DocumentRef-something-1")).to be false
70
+ end
71
+ end
72
+ end
73
+ context "normalize" do
74
+ it "normalizes simple licenses" do
75
+ expect(Spdx.normalize("MIT")).to eq "MIT"
76
+ expect(Spdx.normalize("mit")).to eq "MIT"
77
+ expect(Spdx.normalize("MiT")).to eq "MIT"
78
+ expect(Spdx.normalize("(MiT)")).to eq "MIT"
79
+ expect(Spdx.normalize("(((MiT)))")).to eq "MIT"
80
+ expect(Spdx.normalize("LicenseRef-MIT-style-1")).to eq "LicenseRef-MIT-style-1"
81
+ expect(Spdx.normalize("DocumentRef-something-1:LicenseRef-MIT-style-1")).to eq "DocumentRef-something-1:LicenseRef-MIT-style-1"
82
+ expect(Spdx.normalize("Apache-2.0+")).to eq "Apache-2.0+"
83
+ expect(Spdx.normalize("apache-2.0+")).to eq "Apache-2.0+"
84
+ end
85
+ it "normalizes NONE/NOASSERTION" do
86
+ expect(Spdx.normalize("NONE")).to eq "NONE"
87
+ expect(Spdx.normalize("NOASSERTION")).to eq "NOASSERTION"
88
+ end
89
+ it "normalizes boolean expressions" do
90
+ expect(Spdx.normalize("mit AND gPL-2.0")).to eq "MIT AND GPL-2.0"
91
+ expect(Spdx.normalize("mit OR gPL-2.0")).to eq "MIT OR GPL-2.0"
92
+ expect(Spdx.normalize("mit OR gPL-2.0")).to eq "MIT OR GPL-2.0"
93
+
94
+ # With top level parens
95
+ expect(Spdx.normalize("mit AND gPL-2.0", top_level_parens: true)).to eq "(MIT AND GPL-2.0)"
96
+ expect(Spdx.normalize("mit OR gPL-2.0", top_level_parens: true)).to eq "(MIT OR GPL-2.0)"
97
+ expect(Spdx.normalize("mit OR gPL-2.0", top_level_parens: true)).to eq "(MIT OR GPL-2.0)"
98
+
99
+ # Does semantic grouping
100
+ expect(Spdx.normalize("mit OR gPL-2.0 AND apAcHe-2.0+")).to eq "MIT OR (GPL-2.0 AND Apache-2.0+)"
101
+
102
+ # But also preserves original groups
103
+ expect(Spdx.normalize("(mit OR gPL-2.0) AND apAcHe-2.0+")).to eq "(MIT OR GPL-2.0) AND Apache-2.0+"
104
+ end
105
+ it "normalizes WITH expressions" do
106
+ expect(Spdx.normalize("GPL-2.0-only WITH Classpath-exception-2.0")).to eq "GPL-2.0-only WITH Classpath-exception-2.0"
107
+ expect(Spdx.normalize("Gpl-2.0-ONLY WITH ClassPath-exception-2.0")).to eq "GPL-2.0-only WITH Classpath-exception-2.0"
108
+
109
+ # With top level parens
110
+ expect(Spdx.normalize("GPL-2.0-only WITH Classpath-exception-2.0", top_level_parens: true)).to eq "(GPL-2.0-only WITH Classpath-exception-2.0)"
111
+ expect(Spdx.normalize("Gpl-2.0-ONLY WITH ClassPath-exception-2.0", top_level_parens: true)).to eq "(GPL-2.0-only WITH Classpath-exception-2.0)"
112
+
113
+ expect(Spdx.normalize("EPL-2.0 OR (GPL-2.0-only WITH Classpath-exception-2.0)")).to eq "EPL-2.0 OR (GPL-2.0-only WITH Classpath-exception-2.0)"
114
+ expect(Spdx.normalize("epl-2.0 OR (gpl-2.0-only WITH classpath-exception-2.0)")).to eq "EPL-2.0 OR (GPL-2.0-only WITH Classpath-exception-2.0)"
115
+ expect(Spdx.normalize("epl-2.0 OR gpl-2.0-only WITH classpath-exception-2.0")).to eq "EPL-2.0 OR (GPL-2.0-only WITH Classpath-exception-2.0)"
116
+ expect(Spdx.normalize("epl-2.0 OR gpl-2.0-only WITH classpath-exception-2.0 AND mpl-2.0+")).to eq "EPL-2.0 OR ((GPL-2.0-only WITH Classpath-exception-2.0) AND MPL-2.0+)"
208
117
  end
209
118
  end
210
119
  context "licenses" do
211
120
  it "returns a list of possible licenses" do
212
- expect(Spdx.parse_spdx("MIT OR MPL-2.0").licenses).to eq ["MIT", "MPL-2.0"]
121
+ expect(Spdx.parse("MIT OR MPL-2.0").licenses).to eq ["MIT", "MPL-2.0"]
213
122
  end
214
123
  it "returns empty array for NONE or NOASSERTION" do
215
- expect(Spdx.parse_spdx("NONE").licenses).to eq []
216
- expect(Spdx.parse_spdx("NOASSERTION").licenses).to eq []
124
+ expect(Spdx.parse("NONE").licenses).to eq []
125
+ expect(Spdx.parse("NOASSERTION").licenses).to eq []
126
+ end
127
+ it "returns LicenseRefs" do
128
+ expect(Spdx.parse("MIT OR LicenseRef-MIT-style-1").licenses).to eq %w[MIT LicenseRef-MIT-style-1]
129
+ end
130
+ it "returns DocumentRefs" do
131
+ expect(Spdx.parse("MIT OR DocumentRef-something-1:LicenseRef-MIT-style-1").licenses).to eq %w[MIT DocumentRef-something-1:LicenseRef-MIT-style-1]
217
132
  end
218
133
  end
219
134
 
220
135
  context "exceptions" do
221
- it "parses a valid spdx with expression" do
222
- expect(Spdx.valid_spdx?("EPL-2.0 OR (GPL-2.0-only WITH Classpath-exception-2.0)")).to be true
136
+ it "parses a valid spdx WITH expression" do
137
+ expect(Spdx.valid?("EPL-2.0 OR (GPL-2.0-only WITH Classpath-exception-2.0)")).to be true
223
138
  end
224
139
  it "returns false for a license in the exception spot" do
225
- expect(Spdx.valid_spdx?("EPL-2.0 OR (GPL-2.0-only WITH AGPL-3.0)")).to be false
140
+ expect(Spdx.valid?("EPL-2.0 OR (GPL-2.0-only WITH AGPL-3.0)")).to be false
226
141
  end
227
142
  it "provides full details for a parse error" do
228
- expect { Spdx.parse_spdx("MIT OR ((WHAT)") }.to raise_error(SpdxGrammar::SpdxParseError, "Unable to parse expression '(MIT OR ((WHAT))'. Parse error at offset: 0")
143
+ expect { Spdx.parse("MIT OR ((WHAT)") }.to raise_error(SpdxGrammar::SpdxParseError, "Unable to parse expression 'MIT OR ((WHAT)'. Parse error at offset: 3")
229
144
  end
230
145
  end
231
146
  end
metadata CHANGED
@@ -1,29 +1,15 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: spdx
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.0.12
4
+ version: 4.0.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Tidelift, Inc.
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-07-10 00:00:00.000000000 Z
11
+ date: 2021-02-08 00:00:00.000000000 Z
12
12
  dependencies:
13
- - !ruby/object:Gem::Dependency
14
- name: fuzzy_match
15
- requirement: !ruby/object:Gem::Requirement
16
- requirements:
17
- - - "~>"
18
- - !ruby/object:Gem::Version
19
- version: '2.1'
20
- type: :runtime
21
- prerelease: false
22
- version_requirements: !ruby/object:Gem::Requirement
23
- requirements:
24
- - - "~>"
25
- - !ruby/object:Gem::Version
26
- version: '2.1'
27
13
  - !ruby/object:Gem::Dependency
28
14
  name: treetop
29
15
  requirement: !ruby/object:Gem::Requirement
@@ -164,7 +150,7 @@ requirements: []
164
150
  rubygems_version: 3.0.8
165
151
  signing_key:
166
152
  specification_version: 4
167
- summary: A SPDX license normalizer
153
+ summary: A SPDX license parser
168
154
  test_files:
169
155
  - spec/spdx_spec.rb
170
156
  - spec/spec_helper.rb