120 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			120 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| require "dependency"
 | |
| 
 | |
| describe Dependency do
 | |
|   alias_matcher :be_a_build_dependency, :be_build
 | |
| 
 | |
|   describe "::new" do
 | |
|     it "accepts a single tag" do
 | |
|       dep = described_class.new("foo", %w[bar])
 | |
|       expect(dep.tags).to eq(%w[bar])
 | |
|     end
 | |
| 
 | |
|     it "accepts multiple tags" do
 | |
|       dep = described_class.new("foo", %w[bar baz])
 | |
|       expect(dep.tags.sort).to eq(%w[bar baz].sort)
 | |
|     end
 | |
| 
 | |
|     it "preserves symbol tags" do
 | |
|       dep = described_class.new("foo", [:build])
 | |
|       expect(dep.tags).to eq([:build])
 | |
|     end
 | |
| 
 | |
|     it "accepts symbol and string tags" do
 | |
|       dep = described_class.new("foo", [:build, "bar"])
 | |
|       expect(dep.tags).to eq([:build, "bar"])
 | |
|     end
 | |
| 
 | |
|     it "rejects nil names" do
 | |
|       expect { described_class.new(nil) }.to raise_error(ArgumentError)
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   describe "::merge_repeats" do
 | |
|     it "merges duplicate dependencies" do
 | |
|       dep = described_class.new("foo", [:build], nil, "foo")
 | |
|       dep2 = described_class.new("foo", ["bar"], nil, "foo2")
 | |
|       dep3 = described_class.new("xyz", ["abc"], nil, "foo")
 | |
|       merged = described_class.merge_repeats([dep, dep2, dep3])
 | |
|       expect(merged.count).to eq(2)
 | |
|       expect(merged.first).to be_a described_class
 | |
| 
 | |
|       foo_named_dep = merged.find { |d| d.name == "foo" }
 | |
|       expect(foo_named_dep.tags).to eq(["bar"])
 | |
|       expect(foo_named_dep.option_names).to include("foo")
 | |
|       expect(foo_named_dep.option_names).to include("foo2")
 | |
| 
 | |
|       xyz_named_dep = merged.find { |d| d.name == "xyz" }
 | |
|       expect(xyz_named_dep.tags).to eq(["abc"])
 | |
|       expect(xyz_named_dep.option_names).to include("foo")
 | |
|       expect(xyz_named_dep.option_names).not_to include("foo2")
 | |
|     end
 | |
| 
 | |
|     it "merges necessity tags" do
 | |
|       required_dep = described_class.new("foo")
 | |
|       recommended_dep = described_class.new("foo", [:recommended])
 | |
|       optional_dep = described_class.new("foo", [:optional])
 | |
| 
 | |
|       deps = described_class.merge_repeats([required_dep, recommended_dep])
 | |
|       expect(deps.count).to eq(1)
 | |
|       expect(deps.first).to be_required
 | |
|       expect(deps.first).not_to be_recommended
 | |
|       expect(deps.first).not_to be_optional
 | |
| 
 | |
|       deps = described_class.merge_repeats([required_dep, optional_dep])
 | |
|       expect(deps.count).to eq(1)
 | |
|       expect(deps.first).to be_required
 | |
|       expect(deps.first).not_to be_recommended
 | |
|       expect(deps.first).not_to be_optional
 | |
| 
 | |
|       deps = described_class.merge_repeats([recommended_dep, optional_dep])
 | |
|       expect(deps.count).to eq(1)
 | |
|       expect(deps.first).not_to be_required
 | |
|       expect(deps.first).to be_recommended
 | |
|       expect(deps.first).not_to be_optional
 | |
|     end
 | |
| 
 | |
|     it "merges temporality tags" do
 | |
|       normal_dep = described_class.new("foo")
 | |
|       build_dep = described_class.new("foo", [:build])
 | |
| 
 | |
|       deps = described_class.merge_repeats([normal_dep, build_dep])
 | |
|       expect(deps.count).to eq(1)
 | |
|       expect(deps.first).not_to be_a_build_dependency
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   specify "equality" do
 | |
|     foo1 = described_class.new("foo")
 | |
|     foo2 = described_class.new("foo")
 | |
|     expect(foo1).to eq(foo2)
 | |
|     expect(foo1).to eql(foo2)
 | |
| 
 | |
|     bar = described_class.new("bar")
 | |
|     expect(foo1).not_to eq(bar)
 | |
|     expect(foo1).not_to eql(bar)
 | |
| 
 | |
|     foo3 = described_class.new("foo", [:build])
 | |
|     expect(foo1).not_to eq(foo3)
 | |
|     expect(foo1).not_to eql(foo3)
 | |
|   end
 | |
| 
 | |
|   describe "#tap" do
 | |
|     it "returns a tap passed a fully-qualified name" do
 | |
|       dependency = described_class.new("foo/bar/dog")
 | |
|       expect(dependency.tap).to eq(Tap.new("foo", "bar"))
 | |
|     end
 | |
| 
 | |
|     it "returns no tap passed a simple name" do
 | |
|       dependency = described_class.new("dog")
 | |
|       expect(dependency.tap).to be_nil
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   specify "#option_names" do
 | |
|     dependency = described_class.new("foo/bar/dog")
 | |
|     expect(dependency.option_names).to eq(%w[dog])
 | |
|   end
 | |
| end
 | 
