summaryrefslogtreecommitdiffstats
path: root/base/process_util_unittest.cc
diff options
context:
space:
mode:
authorbradchen@google.com <bradchen@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2011-07-15 23:55:21 +0000
committerbradchen@google.com <bradchen@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2011-07-15 23:55:21 +0000
commitca7c456246121d7e17c22181f0a76eb5c79d3ac0 (patch)
tree0d79285f4e3c0b1e0239225917c976720e9a0096 /base/process_util_unittest.cc
parent3c52ba7a44c24fed4cc3991e9ceae0f366323521 (diff)
downloadchromium_src-ca7c456246121d7e17c22181f0a76eb5c79d3ac0.zip
chromium_src-ca7c456246121d7e17c22181f0a76eb5c79d3ac0.tar.gz
chromium_src-ca7c456246121d7e17c22181f0a76eb5c79d3ac0.tar.bz2
Add a "clone" option to base/process_util.h:LaunchProcess(). Useful inside Linux sandbox.
BUG=nativeclient:480 TEST=base/process_util_unittest.cc Review URL: http://codereview.chromium.org/7401002 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@92771 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/process_util_unittest.cc')
-rw-r--r--base/process_util_unittest.cc24
1 files changed, 17 insertions, 7 deletions
diff --git a/base/process_util_unittest.cc b/base/process_util_unittest.cc
index 5256b37..405beb4 100644
--- a/base/process_util_unittest.cc
+++ b/base/process_util_unittest.cc
@@ -24,6 +24,7 @@
#include <errno.h>
#include <malloc.h>
#include <glib.h>
+#include <sched.h>
#endif
#if defined(OS_POSIX)
#include <dlfcn.h>
@@ -495,7 +496,8 @@ TEST_F(ProcessUtilTest, FDRemapping) {
namespace {
-std::string TestLaunchProcess(const base::environment_vector& env_changes) {
+std::string TestLaunchProcess(const base::environment_vector& env_changes,
+ const int clone_flags) {
std::vector<std::string> args;
base::file_handle_mapping_vector fds_to_remap;
@@ -511,6 +513,7 @@ std::string TestLaunchProcess(const base::environment_vector& env_changes) {
options.wait = true;
options.environ = &env_changes;
options.fds_to_remap = &fds_to_remap;
+ options.clone_flags = clone_flags;
EXPECT_TRUE(base::LaunchProcess(args, options, NULL));
PCHECK(HANDLE_EINTR(close(fds[1])) == 0);
@@ -536,29 +539,36 @@ const char kLargeString[] =
TEST_F(ProcessUtilTest, LaunchProcess) {
base::environment_vector env_changes;
+ const int no_clone_flags = 0;
env_changes.push_back(std::make_pair(std::string("BASE_TEST"),
std::string("bar")));
- EXPECT_EQ("bar\n", TestLaunchProcess(env_changes));
+ EXPECT_EQ("bar\n", TestLaunchProcess(env_changes, no_clone_flags));
env_changes.clear();
EXPECT_EQ(0, setenv("BASE_TEST", "testing", 1 /* override */));
- EXPECT_EQ("testing\n", TestLaunchProcess(env_changes));
+ EXPECT_EQ("testing\n", TestLaunchProcess(env_changes, no_clone_flags));
env_changes.push_back(std::make_pair(std::string("BASE_TEST"),
std::string("")));
- EXPECT_EQ("\n", TestLaunchProcess(env_changes));
+ EXPECT_EQ("\n", TestLaunchProcess(env_changes, no_clone_flags));
env_changes[0].second = "foo";
- EXPECT_EQ("foo\n", TestLaunchProcess(env_changes));
+ EXPECT_EQ("foo\n", TestLaunchProcess(env_changes, no_clone_flags));
env_changes.clear();
EXPECT_EQ(0, setenv("BASE_TEST", kLargeString, 1 /* override */));
- EXPECT_EQ(std::string(kLargeString) + "\n", TestLaunchProcess(env_changes));
+ EXPECT_EQ(std::string(kLargeString) + "\n",
+ TestLaunchProcess(env_changes, no_clone_flags));
env_changes.push_back(std::make_pair(std::string("BASE_TEST"),
std::string("wibble")));
- EXPECT_EQ("wibble\n", TestLaunchProcess(env_changes));
+ EXPECT_EQ("wibble\n", TestLaunchProcess(env_changes, no_clone_flags));
+
+#if defined(OS_LINUX)
+ // test a non-trival value for clone_flags
+ EXPECT_EQ("wibble\n", TestLaunchProcess(env_changes, CLONE_FS | SIGCHLD));
+#endif
}
TEST_F(ProcessUtilTest, AlterEnvironment) {