aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarkus Reiter2017-02-27 12:55:44 +0100
committerGitHub2017-02-27 12:55:44 +0100
commit0dfe85df1376097ae966f6d710df716ad9a38ff2 (patch)
treeecb8ad5c660a0a312dc14fd5ab1fa46c1b93a298
parent7db5f7ce60e0f5a2d70d5009d9cae3a2b19afe47 (diff)
parentdda5d3ac0564cb491f9d55f2b0d2476d40ee1ee9 (diff)
downloadbrew-0dfe85df1376097ae966f6d710df716ad9a38ff2.tar.bz2
Merge pull request #2207 from reitermarkus/spec-dependency_collector
Convert DependencyCollector test to spec.
-rw-r--r--Library/Homebrew/test/dependency_collector_spec.rb137
-rw-r--r--Library/Homebrew/test/dependency_collector_test.rb148
2 files changed, 137 insertions, 148 deletions
diff --git a/Library/Homebrew/test/dependency_collector_spec.rb b/Library/Homebrew/test/dependency_collector_spec.rb
new file mode 100644
index 000000000..82d117939
--- /dev/null
+++ b/Library/Homebrew/test/dependency_collector_spec.rb
@@ -0,0 +1,137 @@
+require "dependency_collector"
+
+RSpec::Matchers.alias_matcher :be_a_build_requirement, :be_build
+
+describe DependencyCollector do
+ def find_dependency(name)
+ subject.deps.find { |dep| dep.name == name }
+ end
+
+ def find_requirement(klass)
+ subject.requirements.find { |req| req.is_a? klass }
+ end
+
+ after(:each) do
+ described_class.clear_cache
+ end
+
+ describe "#add" do
+ specify "dependency creation" do
+ subject.add "foo" => :build
+ subject.add "bar" => ["--universal", :optional]
+ expect(find_dependency("foo")).to be_an_instance_of(Dependency)
+ expect(find_dependency("bar").tags.count).to eq(2)
+ end
+
+ it "returns the created dependency" do
+ expect(subject.add("foo")).to eq(Dependency.new("foo"))
+ end
+
+ specify "requirement creation" do
+ subject.add :x11
+ expect(find_requirement(X11Requirement)).to be_an_instance_of(X11Requirement)
+ end
+
+ it "deduplicates requirements" do
+ 2.times { subject.add :x11 }
+ expect(subject.requirements.count).to eq(1)
+ end
+
+ specify "requirement tags" do
+ subject.add x11: "2.5.1"
+ subject.add xcode: :build
+ expect(find_requirement(X11Requirement).tags).to be_empty
+ expect(find_requirement(XcodeRequirement)).to be_a_build_requirement
+ end
+
+ specify "x11 without tag" do
+ subject.add :x11
+ expect(find_requirement(X11Requirement).tags).to be_empty
+ end
+
+ specify "x11 with minimum version" do
+ subject.add x11: "2.5.1"
+ expect(find_requirement(X11Requirement).min_version.to_s).to eq("2.5.1")
+ end
+
+ specify "x11 with tag" do
+ subject.add x11: :optional
+ expect(find_requirement(X11Requirement)).to be_optional
+ end
+
+ specify "x11 with minimum version and tag" do
+ subject.add x11: ["2.5.1", :optional]
+ dep = find_requirement(X11Requirement)
+ expect(dep.min_version.to_s).to eq("2.5.1")
+ expect(dep).to be_optional
+ end
+
+ specify "ant dependency" do
+ subject.add ant: :build
+ expect(find_dependency("ant")).to eq(Dependency.new("ant", [:build]))
+ end
+
+ it "doesn't mutate the dependency spec" do
+ spec = { "foo" => :optional }
+ copy = spec.dup
+ subject.add(spec)
+ expect(spec).to eq(copy)
+ end
+
+ it "creates a resource dependency from a '.git' URL" do
+ resource = Resource.new
+ resource.url("git://example.com/foo/bar.git")
+ expect(subject.add(resource)).to be_an_instance_of(GitRequirement)
+ end
+
+ it "creates a resource dependency from a '.7z' URL" do
+ resource = Resource.new
+ resource.url("http://example.com/foo.7z")
+ expect(subject.add(resource)).to eq(Dependency.new("p7zip", [:build]))
+ end
+
+ it "creates a resource dependency from a '.gz' URL" do
+ resource = Resource.new
+ resource.url("http://example.com/foo.tar.gz")
+ expect(subject.add(resource)).to be nil
+ end
+
+ it "creates a resource dependency from a '.lz' URL" do
+ resource = Resource.new
+ resource.url("http://example.com/foo.lz")
+ expect(subject.add(resource)).to eq(Dependency.new("lzip", [:build]))
+ end
+
+ it "creates a resource dependency from a '.lha' URL" do
+ resource = Resource.new
+ resource.url("http://example.com/foo.lha")
+ expect(subject.add(resource)).to eq(Dependency.new("lha", [:build]))
+ end
+
+ it "creates a resource dependency from a '.lzh' URL" do
+ resource = Resource.new
+ resource.url("http://example.com/foo.lzh")
+ expect(subject.add(resource)).to eq(Dependency.new("lha", [:build]))
+ end
+
+ it "creates a resource dependency from a '.rar' URL" do
+ resource = Resource.new
+ resource.url("http://example.com/foo.rar")
+ expect(subject.add(resource)).to eq(Dependency.new("unrar", [:build]))
+ end
+
+ it "raises a TypeError for unknown classes" do
+ expect { subject.add(Class.new) }.to raise_error(TypeError)
+ end
+
+ it "raises a TypeError for unknown Types" do
+ expect { subject.add(Object.new) }.to raise_error(TypeError)
+ end
+
+ it "raises a TypeError for a Resource with an unknown download strategy" do
+ resource = Resource.new
+ resource.download_strategy = Class.new
+ expect { subject.add(resource) }.to raise_error(TypeError)
+ end
+ end
+end
diff --git a/Library/Homebrew/test/dependency_collector_test.rb b/Library/Homebrew/test/dependency_collector_test.rb
deleted file mode 100644
index c63d04637..000000000
--- a/Library/Homebrew/test/dependency_collector_test.rb
+++ /dev/null
@@ -1,148 +0,0 @@
-require "testing_env"
-require "dependency_collector"
-
-class DependencyCollectorTests < Homebrew::TestCase
- def find_dependency(name)
- @d.deps.find { |dep| dep.name == name }
- end
-
- def find_requirement(klass)
- @d.requirements.find { |req| req.is_a? klass }
- end
-
- def setup
- super
- @d = DependencyCollector.new
- end
-
- def teardown
- DependencyCollector.clear_cache
- super
- end
-
- def test_dependency_creation
- @d.add "foo" => :build
- @d.add "bar" => ["--universal", :optional]
- assert_instance_of Dependency, find_dependency("foo")
- assert_equal 2, find_dependency("bar").tags.length
- end
-
- def test_add_returns_created_dep
- ret = @d.add "foo"
- assert_equal Dependency.new("foo"), ret
- end
-
- def test_dependency_tags
- assert_predicate Dependency.new("foo", [:build]), :build?
- assert_predicate Dependency.new("foo", [:build, :optional]), :optional?
- assert_includes Dependency.new("foo", ["universal"]).options, "--universal"
- assert_empty Dependency.new("foo").tags
- end
-
- def test_requirement_creation
- @d.add :x11
- assert_instance_of X11Requirement, find_requirement(X11Requirement)
- end
-
- def test_no_duplicate_requirements
- 2.times { @d.add :x11 }
- assert_equal 1, @d.requirements.count
- end
-
- def test_requirement_tags
- @d.add x11: "2.5.1"
- @d.add xcode: :build
- assert_empty find_requirement(X11Requirement).tags
- assert_predicate find_requirement(XcodeRequirement), :build?
- end
-
- def test_x11_no_tag
- @d.add :x11
- assert_empty find_requirement(X11Requirement).tags
- end
-
- def test_x11_min_version
- @d.add x11: "2.5.1"
- assert_equal "2.5.1", find_requirement(X11Requirement).min_version.to_s
- end
-
- def test_x11_tag
- @d.add x11: :optional
- assert_predicate find_requirement(X11Requirement), :optional?
- end
-
- def test_x11_min_version_and_tag
- @d.add x11: ["2.5.1", :optional]
- dep = find_requirement(X11Requirement)
- assert_equal "2.5.1", dep.min_version.to_s
- assert_predicate dep, :optional?
- end
-
- def test_ant_dep
- @d.add ant: :build
- assert_equal find_dependency("ant"), Dependency.new("ant", [:build])
- end
-
- def test_raises_typeerror_for_unknown_classes
- assert_raises(TypeError) { @d.add(Class.new) }
- end
-
- def test_raises_typeerror_for_unknown_types
- assert_raises(TypeError) { @d.add(Object.new) }
- end
-
- def test_does_not_mutate_dependency_spec
- spec = { "foo" => :optional }
- copy = spec.dup
- @d.add(spec)
- assert_equal copy, spec
- end
-
- def test_resource_dep_git_url
- resource = Resource.new
- resource.url("git://example.com/foo/bar.git")
- assert_instance_of GitRequirement, @d.add(resource)
- end
-
- def test_resource_dep_7z_url
- resource = Resource.new
- resource.url("http://example.com/foo.7z")
- assert_equal Dependency.new("p7zip", [:build]), @d.add(resource)
- end
-
- def test_resource_dep_gzip_url
- resource = Resource.new
- resource.url("http://example.com/foo.tar.gz")
- assert_nil @d.add(resource)
- end
-
- def test_resource_dep_lz_url
- resource = Resource.new
- resource.url("http://example.com/foo.lz")
- assert_equal Dependency.new("lzip", [:build]), @d.add(resource)
- end
-
- def test_resource_dep_lha_url
- resource = Resource.new
- resource.url("http://example.com/foo.lha")
- assert_equal Dependency.new("lha", [:build]), @d.add(resource)
- end
-
- def test_resource_dep_lzh_url
- resource = Resource.new
- resource.url("http://example.com/foo.lzh")
- assert_equal Dependency.new("lha", [:build]), @d.add(resource)
- end
-
- def test_resource_dep_rar_url
- resource = Resource.new
- resource.url("http://example.com/foo.rar")
- assert_equal Dependency.new("unrar", [:build]), @d.add(resource)
- end
-
- def test_resource_dep_raises_for_unknown_classes
- resource = Resource.new
- resource.download_strategy = Class.new
- assert_raises(TypeError) { @d.add(resource) }
- end
-end