// Copyright 2014 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef MOJO_SHELL_SHELL_TEST_HELPER_ #define MOJO_SHELL_SHELL_TEST_HELPER_ #include "base/macros.h" #include "base/memory/scoped_ptr.h" #include "base/run_loop.h" #include "mojo/public/cpp/environment/environment.h" #include "mojo/public/interfaces/service_provider/service_provider.mojom.h" #include "mojo/service_manager/service_loader.h" #include "mojo/shell/context.h" class GURL; namespace mojo { class ServiceLoader; namespace shell { // ShellTestHelper is useful for tests to establish a connection to the // ServiceProvider. Invoke Init() to establish the connection. Once done, // service_provider() returns the handle to the ServiceProvider. class ShellTestHelper { public: ShellTestHelper(); ~ShellTestHelper(); void Init(); // Returns a handle to the ServiceProvider. ShellTestHelper owns the // ServiceProvider. ServiceProvider* service_provider() { return service_provider_.get(); } // Sets a ServiceLoader for the specified URL. |loader| is ultimately used on // the thread this class spawns. void SetLoaderForURL(scoped_ptr loader, const GURL& url); private: class TestServiceProvider; Environment environment_; scoped_ptr context_; scoped_ptr test_api_; // ScopedMessagePipeHandle service_provider_handle_; // Client interface for the shell. scoped_ptr local_service_provider_; ServiceProviderPtr service_provider_; DISALLOW_COPY_AND_ASSIGN(ShellTestHelper); }; } // namespace shell } // namespace mojo #endif // MOJO_SHELL_SHELL_TEST_HELPER_