diff --git a/Library/Homebrew/test/dependencies_spec.rb b/Library/Homebrew/test/dependencies_spec.rb
new file mode 100644
index 0000000000000000000000000000000000000000..84ea531819504bf192793d4a0c51f79394c57583
--- /dev/null
+++ b/Library/Homebrew/test/dependencies_spec.rb
@@ -0,0 +1,86 @@
+require "dependencies"
+require "dependency"
+
+describe Dependencies do
+  describe "#<<" do
+    it "returns itself" do
+      expect(subject << Dependency.new("foo")).to eq(subject)
+    end
+
+    it "preserves order" do
+      hash = { 0 => "foo", 1 => "bar", 2 => "baz" }
+
+      subject << Dependency.new(hash[0])
+      subject << Dependency.new(hash[1])
+      subject << Dependency.new(hash[2])
+
+      subject.each_with_index do |dep, i|
+        expect(dep.name).to eq(hash[i])
+      end
+    end
+  end
+
+  specify "#*" do
+    subject << Dependency.new("foo")
+    subject << Dependency.new("bar")
+    expect(subject * ", ").to eq("foo, bar")
+  end
+
+  specify "#to_a" do
+    dep = Dependency.new("foo")
+    subject << dep
+    expect(subject.to_a).to eq([dep])
+  end
+
+  specify "#to_ary" do
+    dep = Dependency.new("foo")
+    subject << dep
+    expect(subject.to_ary).to eq([dep])
+  end
+
+  specify "type helpers" do
+    foo = Dependency.new("foo")
+    bar = Dependency.new("bar", [:optional])
+    baz = Dependency.new("baz", [:build])
+    qux = Dependency.new("qux", [:recommended])
+    quux = Dependency.new("quux")
+    subject << foo << bar << baz << qux << quux
+    expect(subject.required).to eq([foo, quux])
+    expect(subject.optional).to eq([bar])
+    expect(subject.build).to eq([baz])
+    expect(subject.recommended).to eq([qux])
+    expect(subject.default.sort_by(&:name)).to eq([foo, baz, quux, qux].sort_by(&:name))
+  end
+
+  specify "equality" do
+    a = Dependencies.new
+    b = Dependencies.new
+
+    dep = Dependency.new("foo")
+
+    a << dep
+    b << dep
+
+    expect(a).to eq(b)
+    expect(a).to eql(b)
+
+    b << Dependency.new("bar", [:optional])
+
+    expect(a).not_to eq(b)
+    expect(a).not_to eql(b)
+  end
+
+  specify "#empty?" do
+    expect(subject).to be_empty
+
+    subject << Dependency.new("foo")
+    expect(subject).not_to be_empty
+  end
+
+  specify "#inspect" do
+    expect(subject.inspect).to eq("#<Dependencies: []>")
+
+    subject << Dependency.new("foo")
+    expect(subject.inspect).to eq("#<Dependencies: [#<Dependency: \"foo\" []>]>")
+  end
+end
diff --git a/Library/Homebrew/test/dependencies_test.rb b/Library/Homebrew/test/dependencies_test.rb
deleted file mode 100644
index c5444fcbcc0e0424a4c75a4f3a4dfd3aa7dffcb1..0000000000000000000000000000000000000000
--- a/Library/Homebrew/test/dependencies_test.rb
+++ /dev/null
@@ -1,117 +0,0 @@
-require "testing_env"
-require "dependencies"
-require "dependency"
-require "requirements"
-
-class DependenciesTests < Homebrew::TestCase
-  def setup
-    super
-    @deps = Dependencies.new
-  end
-
-  def test_shovel_returns_self
-    assert_same @deps, @deps << Dependency.new("foo")
-  end
-
-  def test_preserves_order
-    hash = { 0 => "foo", 1 => "bar", 2 => "baz" }
-    @deps << Dependency.new(hash[0])
-    @deps << Dependency.new(hash[1])
-    @deps << Dependency.new(hash[2])
-    @deps.each_with_index do |dep, idx|
-      assert_equal hash[idx], dep.name
-    end
-  end
-
-  def test_repetition
-    @deps << Dependency.new("foo")
-    @deps << Dependency.new("bar")
-    assert_equal "foo, bar", @deps*", "
-  end
-
-  def test_to_a
-    dep = Dependency.new("foo")
-    @deps << dep
-    assert_equal [dep], @deps.to_a
-  end
-
-  def test_to_ary
-    dep = Dependency.new("foo")
-    @deps << dep
-    assert_equal [dep], @deps.to_ary
-  end
-
-  def test_type_helpers
-    foo = Dependency.new("foo")
-    bar = Dependency.new("bar", [:optional])
-    baz = Dependency.new("baz", [:build])
-    qux = Dependency.new("qux", [:recommended])
-    quux = Dependency.new("quux")
-    @deps << foo << bar << baz << qux << quux
-    assert_equal [foo, quux], @deps.required
-    assert_equal [bar], @deps.optional
-    assert_equal [baz], @deps.build
-    assert_equal [qux], @deps.recommended
-    assert_equal [foo, baz, quux, qux].sort_by(&:name), @deps.default.sort_by(&:name)
-  end
-
-  def test_equality
-    a = Dependencies.new
-    b = Dependencies.new
-
-    dep = Dependency.new("foo")
-
-    a << dep
-    b << dep
-
-    assert_equal a, b
-    assert_eql a, b
-
-    b << Dependency.new("bar", [:optional])
-
-    refute_equal a, b
-    refute_eql a, b
-  end
-
-  def test_empty
-    a = Dependencies.new
-    assert a.empty?
-    a << Dependency.new("foo")
-    refute a.empty?
-  end
-
-  def test_inspect
-    a = Dependencies.new
-    assert_equal "#<Dependencies: []>", a.inspect
-    a << Dependency.new("foo")
-    assert_equal "#<Dependencies: [#<Dependency: \"foo\" []>]>", a.inspect
-  end
-end
-
-class RequirementsTests < Homebrew::TestCase
-  def setup
-    super
-    @reqs = Requirements.new
-  end
-
-  def test_shovel_returns_self
-    assert_same @reqs, @reqs << Object.new
-  end
-
-  def test_merging_multiple_dependencies
-    @reqs << X11Requirement.new << X11Requirement.new
-    assert_equal 1, @reqs.count
-    @reqs << Requirement.new
-    assert_equal 2, @reqs.count
-  end
-
-  def test_comparison_prefers_larger
-    @reqs << X11Requirement.new << X11Requirement.new("x11", %w[2.6])
-    assert_equal [X11Requirement.new("x11", %w[2.6])], @reqs.to_a
-  end
-
-  def test_comparison_does_not_merge_smaller
-    @reqs << X11Requirement.new("x11", %w[2.6]) << X11Requirement.new
-    assert_equal [X11Requirement.new("x11", %w[2.6])], @reqs.to_a
-  end
-end
diff --git a/Library/Homebrew/test/requirements_spec.rb b/Library/Homebrew/test/requirements_spec.rb
new file mode 100644
index 0000000000000000000000000000000000000000..3111a7c9c91a4907849c05dd728a22f556718d7b
--- /dev/null
+++ b/Library/Homebrew/test/requirements_spec.rb
@@ -0,0 +1,26 @@
+require "requirements"
+
+describe Requirements do
+  describe "#<<" do
+    it "returns itself" do
+      expect(subject << Object.new).to be(subject)
+    end
+
+    it "merges duplicate requirements" do
+      subject << X11Requirement.new << X11Requirement.new
+      expect(subject.count).to eq(1)
+      subject << Requirement.new
+      expect(subject.count).to eq(2)
+    end
+
+    it "prefers the larger requirement when merging duplicates" do
+      subject << X11Requirement.new << X11Requirement.new("x11", %w[2.6])
+      expect(subject.to_a).to eq([X11Requirement.new("x11", %w[2.6])])
+    end
+
+    it "does not use the smaller requirement when merging duplicates" do
+      subject << X11Requirement.new("x11", %w[2.6]) << X11Requirement.new
+      expect(subject.to_a).to eq([X11Requirement.new("x11", %w[2.6])])
+    end
+  end
+end