From: Zac Medico Date: Thu, 21 Jun 2007 20:36:22 +0000 (-0000) Subject: Autodetect if sandbox is active in order to prevent recursive sandbox invocation... X-Git-Tag: v2.2_pre1~1200 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=50dc22b8f85c5b1b5911a200f0b74257ed962461;p=portage.git Autodetect if sandbox is active in order to prevent recursive sandbox invocation. Thanks to Brian Harring for the suggestion. svn path=/main/trunk/; revision=6917 --- diff --git a/pym/portage/__init__.py b/pym/portage/__init__.py index d6afb9d9d..bf66dc4d2 100644 --- a/pym/portage/__init__.py +++ b/pym/portage/__init__.py @@ -2423,7 +2423,7 @@ def spawn(mystring, mysettings, debug=0, free=0, droppriv=0, sesandbox=0, **keyw (not droppriv and "sandbox" not in features and \ "usersandbox" not in features)) - if free: + if free or "SANDBOX_ACTIVE" in os.environ: keywords["opt_name"] += " bash" spawn_func = portage.process.spawn_bash else: diff --git a/pym/portage/tests/ebuild/test_spawn.py b/pym/portage/tests/ebuild/test_spawn.py index c694566f2..66e8f9ea7 100644 --- a/pym/portage/tests/ebuild/test_spawn.py +++ b/pym/portage/tests/ebuild/test_spawn.py @@ -16,10 +16,8 @@ class SpawnTestCase(TestCase): os.close(fd) null_fd = os.open('/dev/null', os.O_RDWR) test_string = 2 * "blah blah blah\n" - # use free=1 to disable sandbox so that this test can run inside a - # sandbox (sandbox in sandbox is not currently allowed) spawn("echo -n '%s'" % test_string, settings, logfile=logfile, - free=1, fd_pipes={0:sys.stdin.fileno(), 1:null_fd, 2:null_fd}) + fd_pipes={0:sys.stdin.fileno(), 1:null_fd, 2:null_fd}) os.close(null_fd) f = open(logfile, 'r') log_content = f.read()