# frozen_string_literal: true RSpec.describe 'integration test' do [ Licensee::Projects::FSProject, Licensee::Projects::GitProject ].each do |project_type| context "with a #{project_type} project" do subject { project_type.new(project_path, arguments) } let(:filename) { 'LICENSE' } let(:license) { Licensee::License.find('mit') } let(:other_license) { Licensee::License.find('other') } let(:content) { license.content } let(:license_path) { File.expand_path(filename, project_path) } let(:arguments) { {} } context 'fixtures' do let(:fixture) { 'mit' } let(:project_path) { fixture_path(fixture) } let(:git_path) { File.expand_path('.git', project_path) } if project_type == Licensee::Projects::GitProject before { git_init(project_path) } after { FileUtils.rm_rf(git_path) } end context 'with a folder named license' do let(:fixture) { 'license-folder' } it "doesn't match" do expect(subject.license).to be_nil end end context 'with no license files' do let(:project_path) { Dir.mktmpdir } let(:file_path) { File.expand_path('foo.md', project_path) } before do File.write(file_path, 'bar') if project_type == Licensee::Projects::GitProject git_init(project_path) end end after { FileUtils.rm_rf(project_path) } it 'returns nil' do expect(subject.license).to be_nil expect(subject.license_files).to be_empty expect(subject.matched_file).to be_nil expect(subject.matched_files).to be_empty end end context 'with LICENSE.lesser' do let(:license) { Licensee::License.find('lgpl-3.0') } let(:fixture) { 'lgpl' } it 'matches to LGPL' do expect(subject.license).to eql(license) expect(subject.license_file.path).to eql('COPYING.lesser') end end context 'with multiple license files' do let(:fixture) { 'multiple-license-files' } it 'matches other' do expect(subject.license).to eql(other_license) end end context 'with CC-BY-NC-SA' do let(:fixture) { 'cc-by-nc-sa' } it 'matches other' do expect(subject.license).to eql(other_license) end end context 'with CC-BY-ND' do let(:fixture) { 'cc-by-nd' } it 'matches other' do expect(subject.license).to eql(other_license) end end context 'with WRK Modified Apache 2.0.1' do let(:fixture) { 'wrk-modified-apache' } it 'matches other' do expect(subject.license).to eql(other_license) end end context 'with FCPL Modified MPL' do let(:fixture) { 'fcpl-modified-mpl' } it 'matches other' do expect(subject.license).to eql(other_license) end end context 'MPL with HRs removed' do let(:license) { Licensee::License.find('mpl-2.0') } let(:fixture) { 'mpl-without-hrs' } it 'matches to MPL' do expect(subject.license).to eql(license) end end context 'GPL3 with instructions removed' do let(:license) { Licensee::License.find('gpl-3.0') } let(:fixture) { 'gpl3-without-instructions' } it 'matches to GPL3' do expect(subject.license).to eql(license) end end context 'DESCRIPTION file with a LICENSE file' do let(:fixture) { 'description-license' } let(:arguments) { { detect_packages: true } } it 'matches other' do expect(subject.license).to eql(other_license) expect(subject.package_file.path).to eql('DESCRIPTION') end end context 'A license with CRLF line-endings' do let(:license) { Licensee::License.find('gpl-3.0') } let(:fixture) { 'crlf-license' } it 'matches' do expect(subject.license).to eql(license) end end context 'BSD + PATENTS' do let(:license) { Licensee::License.find('other') } let(:fixture) { 'bsd-plus-patents' } it 'returns other' do expect(subject.license).to eql(license) end end context 'BSL' do let(:license) { Licensee::License.find('bsl-1.0') } let(:fixture) { 'bsl' } it 'returns bsl-1.0' do expect(subject.license).to eql(license) end end context 'CC0 as published by CC' do let(:license) { Licensee::License.find('cc0-1.0') } let(:fixture) { 'cc0-cc' } it 'returns cc0-1.0' do expect(subject.license).to eql(license) end end context 'CC0 as published on choosealicense.com 2013-2019' do let(:license) { Licensee::License.find('cc0-1.0') } let(:fixture) { 'cc0-cal2013' } it 'returns cc0-1.0' do expect(subject.license).to eql(license) end end context 'Unlicense without optional line' do let(:license) { Licensee::License.find('unlicense') } let(:fixture) { 'unlicense-noinfo' } it 'returns unlicense' do expect(subject.license).to eql(license) end end context 'MIT w/optional phrase' do let(:license) { Licensee::License.find('mit') } let(:fixture) { 'mit-optional' } it 'returns mit' do expect(subject.license).to eql(license) end end context 'license + README reference' do let(:license) { Licensee::License.find('mit') } let(:fixture) { 'license-with-readme-reference' } let(:arguments) { { detect_readme: true } } it 'determines the project is MIT' do expect(subject.license).to eql(license) end end context 'apache license + README notice' do let(:license) { Licensee::License.find('apache-2.0') } let(:fixture) { 'apache-with-readme-notice' } let(:arguments) { { detect_readme: true } } it 'determines the project is Apache-2.0' do expect(subject.license).to eql(license) end end context 'GPL2 with Markdown formatting' do let(:license) { Licensee::License.find('gpl-2.0') } let(:fixture) { 'markdown-gpl' } it 'matches to GPL2' do expect(subject.license).to eql(license) end end context 'BSD-3-Clause numbered and bulleted' do let(:license) { Licensee::License.find('bsd-3-clause') } let(:fixture) { 'bsd-3-lists' } it 'determines the project is BSD-3-Clause' do expect(subject.license).to eql(license) end end context 'HTML license file' do let(:license) { Licensee::License.find('epl-1.0') } let(:fixture) { 'html' } it 'matches to GPL3' do expect(subject.license).to eql(license) end end end context 'with the license file stubbed' do let(:project_path) { Dir.mktmpdir } before do File.write(license_path, content) if project_type == Licensee::Projects::GitProject git_init(project_path) end end after { FileUtils.rm_rf(project_path) } [ 'LICENSE.md', 'LICENSE.txt', 'LICENSE.md', 'LiCeNSe.Txt', 'LICENSE-MIT', 'MIT-LICENSE', 'licence', 'unlicense' ].each do |filename| context "with a #{filename} file" do let(:filename) { filename } it 'matches the license file' do expect(subject.license).to eql(license) expect(subject.license_file.path).to eql(filename) end end end context 'a package.json file' do let(:content) { '{"license": "mit"}' } let(:filename) { 'package.json' } let(:license) { Licensee::License.find('mit') } let(:arguments) { { detect_packages: true } } it 'matches' do expect(subject.license).to eql(license) expect(subject.package_file.path).to eql(filename) end end context 'a README file' do let(:content) { "## License\n#{license.content}" } let(:filename) { 'README' } let(:license) { Licensee::License.find('mit') } let(:arguments) { { detect_readme: true } } it 'matches' do expect(subject.license).to eql(license) expect(subject.readme_file.path).to eql(filename) end end context 'a DESCRIPTION file' do let(:content) { "Package: test\nLicense: MIT" } let(:filename) { 'DESCRIPTION' } let(:license) { Licensee::License.find('mit') } let(:arguments) { { detect_packages: true } } it 'matches' do expect(subject.license).to eql(license) expect(subject.package_file.path).to eql(filename) end end end end end end