2015-04-09 17:42:54 +08:00
|
|
|
require "testing_env"
|
|
|
|
require "sandbox"
|
|
|
|
|
|
|
|
class SandboxTest < Homebrew::TestCase
|
|
|
|
def setup
|
2017-01-21 11:21:30 +00:00
|
|
|
super
|
2015-04-09 17:42:54 +08:00
|
|
|
skip "sandbox not implemented" unless Sandbox.available?
|
2015-04-28 22:36:54 -04:00
|
|
|
@sandbox = Sandbox.new
|
2015-04-28 22:37:27 -04:00
|
|
|
@dir = Pathname.new(mktmpdir)
|
2015-04-28 22:36:54 -04:00
|
|
|
@file = @dir/"foo"
|
|
|
|
end
|
|
|
|
|
2016-08-14 17:34:54 +01:00
|
|
|
def test_formula?
|
|
|
|
f = formula { url "foo-1.0" }
|
|
|
|
f2 = formula { url "bar-1.0" }
|
|
|
|
f2.stubs(:tap).returns(Tap.fetch("test/tap"))
|
|
|
|
|
2017-01-21 15:46:28 +00:00
|
|
|
ENV["HOMEBREW_SANDBOX"] = "1"
|
2016-08-14 17:34:54 +01:00
|
|
|
assert Sandbox.formula?(f),
|
|
|
|
"Formulae should be sandboxed if --sandbox was passed."
|
|
|
|
|
2017-01-21 15:46:28 +00:00
|
|
|
ENV.delete("HOMEBREW_SANDBOX")
|
2016-08-14 17:34:54 +01:00
|
|
|
assert Sandbox.formula?(f),
|
|
|
|
"Formulae should be sandboxed if in a sandboxed tap."
|
|
|
|
refute Sandbox.formula?(f2),
|
|
|
|
"Formulae should not be sandboxed if not in a sandboxed tap."
|
|
|
|
end
|
|
|
|
|
2016-08-14 17:33:05 +01:00
|
|
|
def test_test?
|
2017-01-21 15:46:28 +00:00
|
|
|
ENV.delete("HOMEBREW_NO_SANDBOX")
|
2016-08-14 17:33:05 +01:00
|
|
|
assert Sandbox.test?,
|
|
|
|
"Tests should be sandboxed unless --no-sandbox was passed."
|
|
|
|
end
|
|
|
|
|
2015-04-09 17:42:54 +08:00
|
|
|
def test_allow_write
|
2015-04-28 22:36:54 -04:00
|
|
|
@sandbox.allow_write @file
|
|
|
|
@sandbox.exec "touch", @file
|
|
|
|
assert_predicate @file, :exist?
|
2015-04-09 17:42:54 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_deny_write
|
|
|
|
shutup do
|
2015-04-28 22:36:54 -04:00
|
|
|
assert_raises(ErrorDuringExecution) { @sandbox.exec "touch", @file }
|
2015-04-09 17:42:54 +08:00
|
|
|
end
|
2015-04-28 22:36:54 -04:00
|
|
|
refute_predicate @file, :exist?
|
2015-04-09 17:42:54 +08:00
|
|
|
end
|
2016-08-11 00:23:02 -07:00
|
|
|
|
|
|
|
def test_complains_on_failure
|
2016-09-17 15:32:44 +01:00
|
|
|
Utils.expects(popen_read: "foo")
|
2017-01-21 15:16:32 +00:00
|
|
|
ENV["HOMEBREW_VERBOSE"] = "1"
|
2016-08-11 00:23:02 -07:00
|
|
|
out, _err = capture_io do
|
|
|
|
assert_raises(ErrorDuringExecution) { @sandbox.exec "false" }
|
|
|
|
end
|
|
|
|
assert_match "foo", out
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_ignores_bogus_python_error
|
|
|
|
with_bogus_error = <<-EOS.undent
|
|
|
|
foo
|
|
|
|
Mar 17 02:55:06 sandboxd[342]: Python(49765) deny file-write-unlink /System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/distutils/errors.pyc
|
|
|
|
bar
|
|
|
|
EOS
|
2016-09-17 15:32:44 +01:00
|
|
|
Utils.expects(popen_read: with_bogus_error)
|
2017-01-21 15:16:32 +00:00
|
|
|
ENV["HOMEBREW_VERBOSE"] = "1"
|
2016-08-11 00:23:02 -07:00
|
|
|
out, _err = capture_io do
|
|
|
|
assert_raises(ErrorDuringExecution) { @sandbox.exec "false" }
|
|
|
|
end
|
|
|
|
refute_predicate out, :empty?
|
|
|
|
assert_match "foo", out
|
|
|
|
assert_match "bar", out
|
|
|
|
refute_match "Python", out
|
|
|
|
end
|
2015-04-09 17:42:54 +08:00
|
|
|
end
|