Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 // Note: This file also partly tests child_main.*. | 5 // Note: This file also partly tests child_main.*. |
| 6 | 6 |
| 7 #include "shell/child_process_host.h" | 7 #include "shell/child_process_host.h" |
| 8 | 8 |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/macros.h" | 10 #include "base/macros.h" |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 42 #define MAYBE_StartJoin StartJoin | 42 #define MAYBE_StartJoin StartJoin |
| 43 #endif // defined(OS_ANDROID) | 43 #endif // defined(OS_ANDROID) |
| 44 // Just tests starting the child process and joining it (without starting an | 44 // Just tests starting the child process and joining it (without starting an |
| 45 // app). | 45 // app). |
| 46 TEST(ChildProcessHostTest, MAYBE_StartJoin) { | 46 TEST(ChildProcessHostTest, MAYBE_StartJoin) { |
| 47 Context context; | 47 Context context; |
| 48 base::MessageLoop message_loop( | 48 base::MessageLoop message_loop( |
| 49 scoped_ptr<base::MessagePump>(new mojo::common::MessagePumpMojo())); | 49 scoped_ptr<base::MessagePump>(new mojo::common::MessagePumpMojo())); |
| 50 context.Init(); | 50 context.Init(); |
| 51 TestChildProcessHost child_process_host(&context); | 51 TestChildProcessHost child_process_host(&context); |
| 52 child_process_host.Start(); | 52 bool require_32_bit = false; |
| 53 child_process_host.Start(require_32_bit); | |
|
Mark Seaborn
2015/09/14 18:38:58
Alternative style is:
child_process_host.Start(fal
Sean Klein
2015/09/15 18:37:50
Done.
| |
| 53 message_loop.Run(); // This should run until |DidStart()|. | 54 message_loop.Run(); // This should run until |DidStart()|. |
| 54 child_process_host.ExitNow(123); | 55 child_process_host.ExitNow(123); |
| 55 int exit_code = child_process_host.Join(); | 56 int exit_code = child_process_host.Join(); |
| 56 VLOG(2) << "Joined child: exit_code = " << exit_code; | 57 VLOG(2) << "Joined child: exit_code = " << exit_code; |
| 57 EXPECT_EQ(123, exit_code); | 58 EXPECT_EQ(123, exit_code); |
| 58 | 59 |
| 59 context.Shutdown(); | 60 context.Shutdown(); |
| 60 } | 61 } |
| 61 | 62 |
| 62 #if defined(OS_ANDROID) | 63 #if defined(OS_ANDROID) |
| 63 // TODO(qsr): Multiprocess shell tests are not supported on android. | 64 // TODO(qsr): Multiprocess shell tests are not supported on android. |
| 64 #define MAYBE_ConnectionError DISABLED_ConnectionError | 65 #define MAYBE_ConnectionError DISABLED_ConnectionError |
| 65 #else | 66 #else |
| 66 #define MAYBE_ConnectionError ConnectionError | 67 #define MAYBE_ConnectionError ConnectionError |
| 67 #endif // defined(OS_ANDROID) | 68 #endif // defined(OS_ANDROID) |
| 68 // Tests that even on connection error, the callback to |StartApp()| will get | 69 // Tests that even on connection error, the callback to |StartApp()| will get |
| 69 // called. | 70 // called. |
| 70 TEST(ChildProcessHostTest, MAYBE_ConnectionError) { | 71 TEST(ChildProcessHostTest, MAYBE_ConnectionError) { |
| 71 Context context; | 72 Context context; |
| 72 base::MessageLoop message_loop( | 73 base::MessageLoop message_loop( |
| 73 scoped_ptr<base::MessagePump>(new mojo::common::MessagePumpMojo())); | 74 scoped_ptr<base::MessagePump>(new mojo::common::MessagePumpMojo())); |
| 74 context.Init(); | 75 context.Init(); |
| 75 TestChildProcessHost child_process_host(&context); | 76 TestChildProcessHost child_process_host(&context); |
| 76 child_process_host.Start(); | 77 bool require_32_bit = false; |
| 78 child_process_host.Start(require_32_bit); | |
| 77 message_loop.Run(); // This should run until |DidStart()|. | 79 message_loop.Run(); // This should run until |DidStart()|. |
| 78 // Send |ExitNow()| first, so that the |StartApp()| below won't actually be | 80 // Send |ExitNow()| first, so that the |StartApp()| below won't actually be |
| 79 // processed, and we'll just get a connection error. | 81 // processed, and we'll just get a connection error. |
| 80 child_process_host.ExitNow(123); | 82 child_process_host.ExitNow(123); |
| 81 mojo::MessagePipe mp; | 83 mojo::MessagePipe mp; |
| 82 mojo::InterfaceRequest<mojo::Application> application_request; | 84 mojo::InterfaceRequest<mojo::Application> application_request; |
| 83 application_request.Bind(mp.handle0.Pass()); | 85 application_request.Bind(mp.handle0.Pass()); |
| 84 // This won't actually be called, but the callback should be run. | 86 // This won't actually be called, but the callback should be run. |
| 85 MojoResult result = MOJO_RESULT_INTERNAL; | 87 MojoResult result = MOJO_RESULT_INTERNAL; |
| 86 child_process_host.StartApp("/does_not_exist/cbvgyuio", | 88 child_process_host.StartApp("/does_not_exist/cbvgyuio", |
| 87 application_request.Pass(), [&result](int32_t r) { | 89 application_request.Pass(), [&result](int32_t r) { |
| 88 result = r; | 90 result = r; |
| 89 base::MessageLoop::current()->QuitWhenIdle(); | 91 base::MessageLoop::current()->QuitWhenIdle(); |
| 90 }); | 92 }); |
| 91 message_loop.Run(); | 93 message_loop.Run(); |
| 92 EXPECT_EQ(MOJO_RESULT_UNKNOWN, result); | 94 EXPECT_EQ(MOJO_RESULT_UNKNOWN, result); |
| 93 int exit_code = child_process_host.Join(); | 95 int exit_code = child_process_host.Join(); |
| 94 VLOG(2) << "Joined child: exit_code = " << exit_code; | 96 VLOG(2) << "Joined child: exit_code = " << exit_code; |
| 95 EXPECT_EQ(123, exit_code); | 97 EXPECT_EQ(123, exit_code); |
| 96 | 98 |
| 97 context.Shutdown(); | 99 context.Shutdown(); |
| 98 } | 100 } |
| 99 | 101 |
| 100 } // namespace | 102 } // namespace |
| 101 } // namespace shell | 103 } // namespace shell |
| OLD | NEW |