OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "mojo/fetcher/about_fetcher.h" |
| 6 |
| 7 #include <utility> |
| 8 |
5 #include "base/at_exit.h" | 9 #include "base/at_exit.h" |
6 #include "base/macros.h" | 10 #include "base/macros.h" |
7 #include "base/memory/scoped_ptr.h" | 11 #include "base/memory/scoped_ptr.h" |
8 #include "base/message_loop/message_loop.h" | 12 #include "base/message_loop/message_loop.h" |
9 #include "base/path_service.h" | 13 #include "base/path_service.h" |
10 #include "base/run_loop.h" | 14 #include "base/run_loop.h" |
11 #include "mojo/application/public/cpp/application_connection.h" | 15 #include "mojo/application/public/cpp/application_connection.h" |
12 #include "mojo/application/public/cpp/application_delegate.h" | 16 #include "mojo/application/public/cpp/application_delegate.h" |
13 #include "mojo/application/public/cpp/application_impl.h" | 17 #include "mojo/application/public/cpp/application_impl.h" |
14 #include "mojo/application/public/cpp/interface_factory.h" | 18 #include "mojo/application/public/cpp/interface_factory.h" |
15 #include "mojo/application/public/interfaces/content_handler.mojom.h" | 19 #include "mojo/application/public/interfaces/content_handler.mojom.h" |
16 #include "mojo/common/weak_binding_set.h" | 20 #include "mojo/common/weak_binding_set.h" |
17 #include "mojo/fetcher/about_fetcher.h" | |
18 #include "mojo/package_manager/package_manager_impl.h" | 21 #include "mojo/package_manager/package_manager_impl.h" |
19 #include "mojo/shell/application_loader.h" | 22 #include "mojo/shell/application_loader.h" |
20 #include "mojo/shell/application_manager.h" | 23 #include "mojo/shell/application_manager.h" |
21 #include "mojo/util/filename_util.h" | 24 #include "mojo/util/filename_util.h" |
22 #include "testing/gtest/include/gtest/gtest.h" | 25 #include "testing/gtest/include/gtest/gtest.h" |
23 | 26 |
24 namespace mojo { | 27 namespace mojo { |
25 namespace fetcher { | 28 namespace fetcher { |
26 namespace { | 29 namespace { |
27 | 30 |
(...skipping 11 matching lines...) Expand all Loading... |
39 // Overridden from ApplicationDelegate: | 42 // Overridden from ApplicationDelegate: |
40 void Initialize(ApplicationImpl* app) override {} | 43 void Initialize(ApplicationImpl* app) override {} |
41 bool ConfigureIncomingConnection(ApplicationConnection* connection) override { | 44 bool ConfigureIncomingConnection(ApplicationConnection* connection) override { |
42 connection->AddService<ContentHandler>(this); | 45 connection->AddService<ContentHandler>(this); |
43 return true; | 46 return true; |
44 } | 47 } |
45 | 48 |
46 // Overridden from InterfaceFactory<ContentHandler>: | 49 // Overridden from InterfaceFactory<ContentHandler>: |
47 void Create(ApplicationConnection* connection, | 50 void Create(ApplicationConnection* connection, |
48 InterfaceRequest<ContentHandler> request) override { | 51 InterfaceRequest<ContentHandler> request) override { |
49 bindings_.AddBinding(this, request.Pass()); | 52 bindings_.AddBinding(this, std::move(request)); |
50 } | 53 } |
51 | 54 |
52 // Overridden from ContentHandler: | 55 // Overridden from ContentHandler: |
53 void StartApplication( | 56 void StartApplication( |
54 InterfaceRequest<Application> application, | 57 InterfaceRequest<Application> application, |
55 URLResponsePtr response, | 58 URLResponsePtr response, |
56 const Callback<void()>& destruct_callback) override { | 59 const Callback<void()>& destruct_callback) override { |
57 response_number_++; | 60 response_number_++; |
58 latest_response_ = response.Pass(); | 61 latest_response_ = std::move(response); |
59 destruct_callback.Run(); | 62 destruct_callback.Run(); |
60 | 63 |
61 // Drop |application| request. This results in the application manager | 64 // Drop |application| request. This results in the application manager |
62 // dropping the ServiceProvider interface request provided by the client | 65 // dropping the ServiceProvider interface request provided by the client |
63 // who made the ConnectToApplication() call. Therefore the client could | 66 // who made the ConnectToApplication() call. Therefore the client could |
64 // listen for connection error of the ServiceProvider interface to learn | 67 // listen for connection error of the ServiceProvider interface to learn |
65 // that StartApplication() has been called. | 68 // that StartApplication() has been called. |
66 } | 69 } |
67 | 70 |
68 size_t response_number_; | 71 size_t response_number_; |
69 URLResponsePtr latest_response_; | 72 URLResponsePtr latest_response_; |
70 WeakBindingSet<ContentHandler> bindings_; | 73 WeakBindingSet<ContentHandler> bindings_; |
71 | 74 |
72 DISALLOW_COPY_AND_ASSIGN(TestContentHandler); | 75 DISALLOW_COPY_AND_ASSIGN(TestContentHandler); |
73 }; | 76 }; |
74 | 77 |
75 class TestLoader : public shell::ApplicationLoader { | 78 class TestLoader : public shell::ApplicationLoader { |
76 public: | 79 public: |
77 explicit TestLoader(ApplicationDelegate* delegate) : delegate_(delegate) {} | 80 explicit TestLoader(ApplicationDelegate* delegate) : delegate_(delegate) {} |
78 ~TestLoader() override {} | 81 ~TestLoader() override {} |
79 | 82 |
80 private: | 83 private: |
81 // Overridden from ApplicationLoader: | 84 // Overridden from ApplicationLoader: |
82 void Load(const GURL& url, InterfaceRequest<Application> request) override { | 85 void Load(const GURL& url, InterfaceRequest<Application> request) override { |
83 app_.reset(new ApplicationImpl(delegate_, request.Pass())); | 86 app_.reset(new ApplicationImpl(delegate_, std::move(request))); |
84 } | 87 } |
85 | 88 |
86 ApplicationDelegate* delegate_; | 89 ApplicationDelegate* delegate_; |
87 scoped_ptr<ApplicationImpl> app_; | 90 scoped_ptr<ApplicationImpl> app_; |
88 | 91 |
89 DISALLOW_COPY_AND_ASSIGN(TestLoader); | 92 DISALLOW_COPY_AND_ASSIGN(TestLoader); |
90 }; | 93 }; |
91 | 94 |
92 class AboutFetcherTest : public testing::Test { | 95 class AboutFetcherTest : public testing::Test { |
93 public: | 96 public: |
(...skipping 14 matching lines...) Expand all Loading... |
108 // This connection error handler will be called when: | 111 // This connection error handler will be called when: |
109 // - TestContentHandler::StartApplication() has been called (please see | 112 // - TestContentHandler::StartApplication() has been called (please see |
110 // comments in that method); or | 113 // comments in that method); or |
111 // - the application manager fails to fetch the requested URL. | 114 // - the application manager fails to fetch the requested URL. |
112 service_provider.set_connection_error_handler( | 115 service_provider.set_connection_error_handler( |
113 [&run_loop]() { run_loop.Quit(); }); | 116 [&run_loop]() { run_loop.Quit(); }); |
114 | 117 |
115 scoped_ptr<shell::ConnectToApplicationParams> params( | 118 scoped_ptr<shell::ConnectToApplicationParams> params( |
116 new shell::ConnectToApplicationParams); | 119 new shell::ConnectToApplicationParams); |
117 params->SetTargetURL(GURL(url)); | 120 params->SetTargetURL(GURL(url)); |
118 params->set_services(service_provider_request.Pass()); | 121 params->set_services(std::move(service_provider_request)); |
119 application_manager_->ConnectToApplication(params.Pass()); | 122 application_manager_->ConnectToApplication(std::move(params)); |
120 | 123 |
121 run_loop.Run(); | 124 run_loop.Run(); |
122 } | 125 } |
123 | 126 |
124 // Overridden from testing::Test: | 127 // Overridden from testing::Test: |
125 void SetUp() override { | 128 void SetUp() override { |
126 base::FilePath shell_dir; | 129 base::FilePath shell_dir; |
127 PathService::Get(base::DIR_MODULE, &shell_dir); | 130 PathService::Get(base::DIR_MODULE, &shell_dir); |
128 scoped_ptr<package_manager::PackageManagerImpl> package_manager( | 131 scoped_ptr<package_manager::PackageManagerImpl> package_manager( |
129 new package_manager::PackageManagerImpl(shell_dir, nullptr)); | 132 new package_manager::PackageManagerImpl(shell_dir, nullptr)); |
130 package_manager->RegisterContentHandler( | 133 package_manager->RegisterContentHandler( |
131 "text/html", GURL("test:html_content_handler")); | 134 "text/html", GURL("test:html_content_handler")); |
132 application_manager_.reset( | 135 application_manager_.reset( |
133 new shell::ApplicationManager(package_manager.Pass())); | 136 new shell::ApplicationManager(std::move(package_manager))); |
134 application_manager_->SetLoaderForURL( | 137 application_manager_->SetLoaderForURL( |
135 make_scoped_ptr(new TestLoader(&html_content_handler_)), | 138 make_scoped_ptr(new TestLoader(&html_content_handler_)), |
136 GURL("test:html_content_handler")); | 139 GURL("test:html_content_handler")); |
137 } | 140 } |
138 | 141 |
139 void TearDown() override { application_manager_.reset(); } | 142 void TearDown() override { application_manager_.reset(); } |
140 | 143 |
141 private: | 144 private: |
142 base::ShadowingAtExitManager at_exit_; | 145 base::ShadowingAtExitManager at_exit_; |
143 TestContentHandler html_content_handler_; | 146 TestContentHandler html_content_handler_; |
(...skipping 23 matching lines...) Expand all Loading... |
167 const URLResponse* response = html_content_handler()->latest_response(); | 170 const URLResponse* response = html_content_handler()->latest_response(); |
168 EXPECT_EQ("about:some_unrecognized_url", response->url); | 171 EXPECT_EQ("about:some_unrecognized_url", response->url); |
169 EXPECT_EQ(404u, response->status_code); | 172 EXPECT_EQ(404u, response->status_code); |
170 EXPECT_EQ("text/html", response->mime_type); | 173 EXPECT_EQ("text/html", response->mime_type); |
171 EXPECT_FALSE(response->body.is_valid()); | 174 EXPECT_FALSE(response->body.is_valid()); |
172 } | 175 } |
173 | 176 |
174 } // namespace | 177 } // namespace |
175 } // namespace fetcher | 178 } // namespace fetcher |
176 } // namespace mojo | 179 } // namespace mojo |
OLD | NEW |