diff options
author | sky <sky@chromium.org> | 2016-03-21 09:38:30 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2016-03-21 16:39:48 +0000 |
commit | 6e47685c9153b1d26ce5d2f955ebd6aea67e09d3 (patch) | |
tree | 241778bc6054cecdaf714078fdc76b853bc20ae2 /mojo/shell/standalone | |
parent | ae7184b6f12adfa37ecca0fbae511aa68fa080e6 (diff) | |
download | chromium_src-6e47685c9153b1d26ce5d2f955ebd6aea67e09d3.zip chromium_src-6e47685c9153b1d26ce5d2f955ebd6aea67e09d3.tar.gz chromium_src-6e47685c9153b1d26ce5d2f955ebd6aea67e09d3.tar.bz2 |
Adds option to run browser tests in mash
At a high level this is what the code does:
. The test launcher creates MojoTestConnector.
. MojoTestConnector creates a BackgroundShell (initially I wanted to
run the shell on the same thread, but that is problematic because I
need to run a nested message loop at times, which the IO thread
doesn't support (the test launcher uses an io thread)).
. A connection is established to mojo:mash_shell.
. MojoTestConnector sets up the state for each test. The connect is not done
with Mojo's child process connection. The base test launching code handles
the actual process launching.
Other random notes:
. --single_process is a slightly different flow.
. The test never finishes. This is because apps that are started don't
all exit when the shell exits. I'm going to look at that next.
R=ben@chromium.org, jam@chromium.org
BUG=581733
Review URL: https://codereview.chromium.org/1806353003
Cr-Commit-Position: refs/heads/master@{#382305}
Diffstat (limited to 'mojo/shell/standalone')
-rw-r--r-- | mojo/shell/standalone/context.cc | 6 | ||||
-rw-r--r-- | mojo/shell/standalone/context.h | 2 |
2 files changed, 6 insertions, 2 deletions
diff --git a/mojo/shell/standalone/context.cc b/mojo/shell/standalone/context.cc index dc0a25b..5b53879 100644 --- a/mojo/shell/standalone/context.cc +++ b/mojo/shell/standalone/context.cc @@ -129,13 +129,15 @@ void Context::Init(scoped_ptr<InitParams> init_params) { "mojo_runner.trace"); } - EnsureEmbedderIsInitialized(); + if (!init_params || init_params->init_edk) + EnsureEmbedderIsInitialized(); shell_runner_ = base::MessageLoop::current()->task_runner(); blocking_pool_ = new base::SequencedWorkerPool(kMaxBlockingPoolThreads, "blocking_pool"); - edk::InitIPCSupport(this, io_thread_->task_runner().get()); + if (!init_params || init_params->init_edk) + edk::InitIPCSupport(this, io_thread_->task_runner().get()); scoped_ptr<NativeRunnerFactory> runner_factory; if (command_line.HasSwitch(switches::kSingleProcess)) { diff --git a/mojo/shell/standalone/context.h b/mojo/shell/standalone/context.h index 09f7942..3c25027 100644 --- a/mojo/shell/standalone/context.h +++ b/mojo/shell/standalone/context.h @@ -37,6 +37,8 @@ class Context : public edk::ProcessDelegate { NativeRunnerDelegate* native_runner_delegate = nullptr; scoped_ptr<catalog::Store> catalog_store; + // If true the edk is initialized. + bool init_edk = true; }; Context(); |