| 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 #include "services/js/test/echo_service.mojom.h" | 5 #include "services/js/test/echo_service.mojom.h" |
| 6 #include "services/js/test/js_application_test_base.h" | 6 #include "services/js/test/js_application_test_base.h" |
| 7 | 7 |
| 8 using mojo::String; | 8 using mojo::String; |
| 9 | 9 |
| 10 namespace js { | 10 namespace js { |
| (...skipping 21 matching lines...) Expand all Loading... |
| 32 class JSServiceProviderEchoTest : public test::JSApplicationTestBase { | 32 class JSServiceProviderEchoTest : public test::JSApplicationTestBase { |
| 33 public: | 33 public: |
| 34 JSServiceProviderEchoTest() : JSApplicationTestBase() {} | 34 JSServiceProviderEchoTest() : JSApplicationTestBase() {} |
| 35 ~JSServiceProviderEchoTest() override {} | 35 ~JSServiceProviderEchoTest() override {} |
| 36 | 36 |
| 37 protected: | 37 protected: |
| 38 // ApplicationTestBase: | 38 // ApplicationTestBase: |
| 39 void SetUp() override { | 39 void SetUp() override { |
| 40 ApplicationTestBase::SetUp(); | 40 ApplicationTestBase::SetUp(); |
| 41 const std::string& url = JSAppURL("echo.js"); | 41 const std::string& url = JSAppURL("echo.js"); |
| 42 // TODO(hansmuller): We should be able to pass a null ServiceProviderPtr |
| 43 // here as the third parameter to ConnectToApplication since the parameter |
| 44 // is annotated as nullable in the mojom, but the JS bindings currently |
| 45 // don't correctly handle a null handle. So instead we allocate (and |
| 46 // immediately close) a MessagePipe. |
| 47 mojo::MessagePipe throwaway_pipe; |
| 48 mojo::ServiceProviderPtr exposed_services; |
| 49 exposed_services.Bind(throwaway_pipe.handle0.Pass()); |
| 42 application_impl()->shell()->ConnectToApplication( | 50 application_impl()->shell()->ConnectToApplication( |
| 43 url, GetProxy(&echo_service_provider_)); | 51 url, GetProxy(&echo_service_provider_), exposed_services.Pass()); |
| 44 } | 52 } |
| 45 | 53 |
| 46 mojo::ServiceProviderPtr echo_service_provider_; | 54 mojo::ServiceProviderPtr echo_service_provider_; |
| 47 | 55 |
| 48 private: | 56 private: |
| 49 MOJO_DISALLOW_COPY_AND_ASSIGN(JSServiceProviderEchoTest); | 57 MOJO_DISALLOW_COPY_AND_ASSIGN(JSServiceProviderEchoTest); |
| 50 }; | 58 }; |
| 51 | 59 |
| 52 struct EchoStringCallback { | 60 struct EchoStringCallback { |
| 53 explicit EchoStringCallback(String *s) : echo_value(s) {} | 61 explicit EchoStringCallback(String *s) : echo_value(s) {} |
| (...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 114 String foo; | 122 String foo; |
| 115 EchoStringCallback callback(&foo); | 123 EchoStringCallback callback(&foo); |
| 116 echo_service->EchoString("foo", callback); | 124 echo_service->EchoString("foo", callback); |
| 117 EXPECT_TRUE(echo_service.WaitForIncomingMethodCall()); | 125 EXPECT_TRUE(echo_service.WaitForIncomingMethodCall()); |
| 118 EXPECT_EQ("foo", foo); | 126 EXPECT_EQ("foo", foo); |
| 119 echo_service->Quit(); | 127 echo_service->Quit(); |
| 120 } | 128 } |
| 121 | 129 |
| 122 } // namespace | 130 } // namespace |
| 123 } // namespace js | 131 } // namespace js |
| OLD | NEW |