Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(634)

Side by Side Diff: mojo/shell/shell_test_helper.h

Issue 298653010: Change Shell / ShellClient to ServiceProvider (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Support content Mojo stuff Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef MOJO_SHELL_SHELL_TEST_HELPER_ 5 #ifndef MOJO_SHELL_SHELL_TEST_HELPER_
6 #define MOJO_SHELL_SHELL_TEST_HELPER_ 6 #define MOJO_SHELL_SHELL_TEST_HELPER_
7 7
8 #include "base/macros.h" 8 #include "base/macros.h"
9 #include "base/memory/scoped_ptr.h" 9 #include "base/memory/scoped_ptr.h"
10 #include "base/run_loop.h" 10 #include "base/run_loop.h"
11 #include "base/threading/thread.h" 11 #include "base/threading/thread.h"
12 #include "mojo/public/cpp/environment/environment.h" 12 #include "mojo/public/cpp/environment/environment.h"
13 #include "mojo/public/interfaces/shell/shell.mojom.h" 13 #include "mojo/public/interfaces/service_provider/service_provider.mojom.h"
14 14
15 namespace base { 15 namespace base {
16 class MessageLoopProxy; 16 class MessageLoopProxy;
17 class RunLoop; 17 class RunLoop;
18 } 18 }
19 19
20 namespace mojo { 20 namespace mojo {
21 namespace shell { 21 namespace shell {
22 22
23 // ShellTestHelper is useful for tests to establish a connection to the Shell. 23 // ShellTestHelper is useful for tests to establish a connection to the
24 // ShellTestHelper does this by spawning a thread and connecting. Invoke Init() 24 // ServiceProvider. ShellTestHelper does this by spawning a thread and
25 // to do this. Once done, shell() returns the handle to the Shell. 25 // connecting. Invoke Init() to do this. Once done, service_provider()
26 // returns the handle to the ServiceProvider.
26 class ShellTestHelper { 27 class ShellTestHelper {
27 public: 28 public:
28 struct State; 29 struct State;
29 30
30 ShellTestHelper(); 31 ShellTestHelper();
31 ~ShellTestHelper(); 32 ~ShellTestHelper();
32 33
33 void Init(); 34 void Init();
34 35
35 // Returns a handle to the Shell. ShellTestHelper owns the shell. 36 // Returns a handle to the ServiceProvider. ShellTestHelper owns the
36 Shell* shell() { return shell_.get(); } 37 // ServiceProvider.
38 ServiceProvider* service_provider() { return service_provider_.get(); }
37 39
38 private: 40 private:
39 class TestShellClient; 41 class TestServiceProvider;
40 42
41 // Invoked once connection has been established. 43 // Invoked once connection has been established.
42 void OnShellStarted(); 44 void OnServiceProviderStarted();
43 45
44 Environment environment_; 46 Environment environment_;
45 47
46 base::Thread shell_thread_; 48 base::Thread service_provider_thread_;
47 49
48 // If non-null we're in Init() and waiting for connection. 50 // If non-null we're in Init() and waiting for connection.
49 scoped_ptr<base::RunLoop> run_loop_; 51 scoped_ptr<base::RunLoop> run_loop_;
50 52
51 // See comment in declaration for details. 53 // See comment in declaration for details.
52 State* state_; 54 State* state_;
53 55
54 // Client interface for the shell. 56 // Client interface for the shell.
55 scoped_ptr<TestShellClient> shell_client_; 57 scoped_ptr<TestServiceProvider> local_service_provider_;
56 58
57 ShellPtr shell_; 59 ServiceProviderPtr service_provider_;
58 60
59 DISALLOW_COPY_AND_ASSIGN(ShellTestHelper); 61 DISALLOW_COPY_AND_ASSIGN(ShellTestHelper);
60 }; 62 };
61 63
62 } // namespace shell 64 } // namespace shell
63 } // namespace mojo 65 } // namespace mojo
64 66
65 #endif // MOJO_SHELL_SHELL_TEST_HELPER_ 67 #endif // MOJO_SHELL_SHELL_TEST_HELPER_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698