Convert brew link
test to spec.
This commit is contained in:
parent
c7121f6be5
commit
ada6a1b09e
56
Library/Homebrew/test/cmd/link_spec.rb
Normal file
56
Library/Homebrew/test/cmd/link_spec.rb
Normal file
@ -0,0 +1,56 @@
|
||||
describe "brew link", :integration_test do
|
||||
it "fails when no argument is given" do
|
||||
expect { brew "link" }
|
||||
.to output(/This command requires a keg argument/).to_stderr
|
||||
.and not_to_output.to_stdout
|
||||
.and be_a_failure
|
||||
end
|
||||
|
||||
it "does not fail if the given Formula is already linked" do
|
||||
setup_test_formula "testball1"
|
||||
|
||||
shutup do
|
||||
expect { brew "install", "testball1" }.to be_a_success
|
||||
expect { brew "link", "testball1" }.to be_a_success
|
||||
end
|
||||
end
|
||||
|
||||
it "links a given Formula" do
|
||||
setup_test_formula "testball1"
|
||||
|
||||
shutup do
|
||||
expect { brew "install", "testball1" }.to be_a_success
|
||||
expect { brew "unlink", "testball1" }.to be_a_success
|
||||
end
|
||||
|
||||
expect { brew "link", "--dry-run", "testball1" }
|
||||
.to output(/Would link/).to_stdout
|
||||
.and not_to_output.to_stderr
|
||||
.and be_a_success
|
||||
|
||||
expect { brew "link", "--dry-run", "--overwrite", "testball1" }
|
||||
.to output(/Would remove/).to_stdout
|
||||
.and not_to_output.to_stderr
|
||||
.and be_a_success
|
||||
|
||||
expect { brew "link", "testball1" }
|
||||
.to output(/Linking/).to_stdout
|
||||
.and not_to_output.to_stderr
|
||||
.and be_a_success
|
||||
end
|
||||
|
||||
it "refuses to link keg-only Formulae" do
|
||||
setup_test_formula "testball1", <<-EOS.undent
|
||||
keg_only "just because"
|
||||
EOS
|
||||
|
||||
shutup do
|
||||
expect { brew "install", "testball1" }.to be_a_success
|
||||
end
|
||||
|
||||
expect { brew "link", "testball1" }
|
||||
.to output(/testball1 is keg-only/).to_stderr
|
||||
.and output(/Note that doing so can interfere with building software\./).to_stdout
|
||||
.and be_a_success
|
||||
end
|
||||
end
|
@ -1,23 +0,0 @@
|
||||
require "testing_env"
|
||||
|
||||
class IntegrationCommandTestLink < IntegrationCommandTestCase
|
||||
def test_link
|
||||
assert_match "This command requires a keg argument", cmd_fail("link")
|
||||
|
||||
setup_test_formula "testball1"
|
||||
cmd("install", "testball1")
|
||||
cmd("link", "testball1")
|
||||
|
||||
cmd("unlink", "testball1")
|
||||
assert_match "Would link", cmd("link", "--dry-run", "testball1")
|
||||
assert_match "Would remove",
|
||||
cmd("link", "--dry-run", "--overwrite", "testball1")
|
||||
assert_match "Linking", cmd("link", "testball1")
|
||||
|
||||
setup_test_formula "testball2", <<-EOS.undent
|
||||
keg_only "just because"
|
||||
EOS
|
||||
cmd("install", "testball2")
|
||||
assert_match "testball2 is keg-only", cmd("link", "testball2")
|
||||
end
|
||||
end
|
Loading…
x
Reference in New Issue
Block a user