mirror of
https://github.com/Homebrew/brew.git
synced 2025-07-14 16:09:03 +08:00
120 lines
3.3 KiB
Ruby
120 lines
3.3 KiB
Ruby
require 'testing_env'
|
|
require 'dependency'
|
|
|
|
class DependencyExpansionTests < Test::Unit::TestCase
|
|
def build_dep(name, tags=[], deps=[])
|
|
dep = Dependency.new(name.to_s, tags)
|
|
dep.stubs(:to_formula).returns(stub(:deps => deps, :name => name))
|
|
dep
|
|
end
|
|
|
|
def setup
|
|
@foo = build_dep(:foo)
|
|
@bar = build_dep(:bar)
|
|
@baz = build_dep(:baz)
|
|
@qux = build_dep(:qux)
|
|
@deps = [@foo, @bar, @baz, @qux]
|
|
@f = stub(:deps => @deps, :name => "f")
|
|
end
|
|
|
|
def test_expand_yields_dependent_and_dep_pairs
|
|
i = 0
|
|
Dependency.expand(@f) do |dependent, dep|
|
|
assert_equal @f, dependent
|
|
assert_equal dep, @deps[i]
|
|
i += 1
|
|
end
|
|
end
|
|
|
|
def test_expand_no_block
|
|
assert_equal @deps, Dependency.expand(@f)
|
|
end
|
|
|
|
def test_expand_prune_all
|
|
assert_empty Dependency.expand(@f) { Dependency.prune }
|
|
end
|
|
|
|
def test_expand_selective_pruning
|
|
deps = Dependency.expand(@f) do |_, dep|
|
|
Dependency.prune if dep.name == 'foo'
|
|
end
|
|
|
|
assert_equal [@bar, @baz, @qux], deps
|
|
end
|
|
|
|
def test_expand_preserves_dependency_order
|
|
@foo.stubs(:to_formula).returns(stub(:name => "f", :deps => [@qux, @baz]))
|
|
assert_equal [@qux, @baz, @foo, @bar], Dependency.expand(@f)
|
|
end
|
|
|
|
def test_expand_skips_optionals_by_default
|
|
@foo.expects(:optional?).returns(true)
|
|
@f = stub(:deps => @deps, :build => stub(:with? => false), :name => "f")
|
|
assert_equal [@bar, @baz, @qux], Dependency.expand(@f)
|
|
end
|
|
|
|
def test_expand_keeps_recommendeds_by_default
|
|
@foo.expects(:recommended?).returns(true)
|
|
@f = stub(:deps => @deps, :build => stub(:with? => true), :name => "f")
|
|
assert_equal @deps, Dependency.expand(@f)
|
|
end
|
|
|
|
def test_merges_repeated_deps_with_differing_options
|
|
@foo2 = build_dep(:foo, ['option'])
|
|
@baz2 = build_dep(:baz, ['option'])
|
|
@deps << @foo2 << @baz2
|
|
deps = [@foo2, @bar, @baz2, @qux]
|
|
deps.zip(Dependency.expand(@f)) do |expected, actual|
|
|
assert_equal expected.tags, actual.tags
|
|
assert_equal expected, actual
|
|
end
|
|
end
|
|
|
|
def test_merger_preserves_env_proc
|
|
env_proc = stub
|
|
dep = Dependency.new("foo", [], env_proc)
|
|
dep.stubs(:to_formula).returns(stub(:deps => []))
|
|
@deps.replace [dep]
|
|
assert_equal env_proc, Dependency.expand(@f).first.env_proc
|
|
end
|
|
|
|
def test_merged_tags_no_dupes
|
|
@foo2 = build_dep(:foo, ['option'])
|
|
@foo3 = build_dep(:foo, ['option'])
|
|
@deps << @foo2 << @foo3
|
|
|
|
assert_equal %w{option}, Dependency.expand(@f).first.tags
|
|
end
|
|
|
|
def test_skip_skips_parent_but_yields_children
|
|
f = stub(:name => "f", :deps => [
|
|
build_dep(:foo, [], [@bar, @baz]),
|
|
build_dep(:foo, [], [@baz]),
|
|
])
|
|
|
|
deps = Dependency.expand(f) do |dependent, dep|
|
|
Dependency.skip if %w{foo qux}.include? dep.name
|
|
end
|
|
|
|
assert_equal [@bar, @baz], deps
|
|
end
|
|
|
|
def test_keep_dep_but_prune_recursive_deps
|
|
f = stub(:name => "f", :deps => [
|
|
build_dep(:foo, [:build], [@bar]),
|
|
build_dep(:baz, [:build]),
|
|
])
|
|
|
|
deps = Dependency.expand(f) do |dependent, dep|
|
|
Dependency.keep_but_prune_recursive_deps if dep.build?
|
|
end
|
|
|
|
assert_equal [@foo, @baz], deps
|
|
end
|
|
|
|
def test_deps_with_collection_argument
|
|
assert_equal [@foo, @bar, @baz, @qux], @f.deps
|
|
assert_equal [@bar, @baz], Dependency.expand(@f, [@bar, @baz])
|
|
end
|
|
end
|