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

Side by Side Diff: content/browser/service_worker/embedded_worker_test_helper.h

Issue 2628553002: ServiceWorker: OnSimpleEventFinished could be called after timed out (Closed)
Patch Set: Updated a unittest Created 3 years, 11 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
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 CONTENT_BROWSER_SERVICE_WORKER_EMBEDDED_WORKER_TEST_HELPER_H_ 5 #ifndef CONTENT_BROWSER_SERVICE_WORKER_EMBEDDED_WORKER_TEST_HELPER_H_
6 #define CONTENT_BROWSER_SERVICE_WORKER_EMBEDDED_WORKER_TEST_HELPER_H_ 6 #define CONTENT_BROWSER_SERVICE_WORKER_EMBEDDED_WORKER_TEST_HELPER_H_
7 7
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include <map> 10 #include <map>
(...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after
150 base::WeakPtr<EmbeddedWorkerTestHelper> AsWeakPtr() { 150 base::WeakPtr<EmbeddedWorkerTestHelper> AsWeakPtr() {
151 return weak_factory_.GetWeakPtr(); 151 return weak_factory_.GetWeakPtr();
152 } 152 }
153 153
154 static net::HttpResponseInfo CreateHttpResponseInfo(); 154 static net::HttpResponseInfo CreateHttpResponseInfo();
155 155
156 protected: 156 protected:
157 // Called when StartWorker, StopWorker and SendMessageToWorker message 157 // Called when StartWorker, StopWorker and SendMessageToWorker message
158 // is sent to the embedded worker. Override if necessary. By default 158 // is sent to the embedded worker. Override if necessary. By default
159 // they verify given parameters and: 159 // they verify given parameters and:
160 // - OnStartWorker calls SimulateWorkerStarted 160 // - OnStartWorker calls SimulateWorkerStarted and binds |request| to
161 // - OnStopWorker calls SimulateWorkerStoped 161 // MockServiceWorkerEventDispatcher
162 // - OnStopWorker calls StopWorkerCallback
falken 2017/01/11 06:31:55 At first glance this seems weird. Why isn't someth
shimazu 2017/01/12 01:45:24 It's because real IPCs can be sent through mojo. C
162 // - OnSendMessageToWorker calls the message's respective On*Event handler 163 // - OnSendMessageToWorker calls the message's respective On*Event handler
falken 2017/01/11 06:31:55 Seems like this would read better as individual co
shimazu 2017/01/12 01:45:24 Done.
163 virtual void OnStartWorker(int embedded_worker_id, 164 virtual void OnStartWorker(
164 int64_t service_worker_version_id, 165 int embedded_worker_id,
165 const GURL& scope, 166 int64_t service_worker_version_id,
166 const GURL& script_url, 167 const GURL& scope,
167 bool pause_after_download); 168 const GURL& script_url,
169 bool pause_after_download,
170 mojom::ServiceWorkerEventDispatcherRequest request);
168 virtual void OnResumeAfterDownload(int embedded_worker_id); 171 virtual void OnResumeAfterDownload(int embedded_worker_id);
169 virtual void OnStopWorker(int embedded_worker_id); 172 virtual void OnStopWorker(
173 const mojom::EmbeddedWorkerInstanceClient::StopWorkerCallback& callback);
170 virtual bool OnMessageToWorker(int thread_id, 174 virtual bool OnMessageToWorker(int thread_id,
171 int embedded_worker_id, 175 int embedded_worker_id,
172 const IPC::Message& message); 176 const IPC::Message& message);
173 177
174 // Called to setup mojo for a new embedded worker. Override to register
175 // interfaces the worker should expose to the browser.
176 virtual void OnSetupMojo(
177 int thread_id,
178 mojom::ServiceWorkerEventDispatcherRequest dispatcher_request);
179
180 // On*Event handlers. Called by the default implementation of 178 // On*Event handlers. Called by the default implementation of
181 // OnMessageToWorker when events are sent to the embedded 179 // OnMessageToWorker when events are sent to the embedded
182 // worker. By default they just return success via 180 // worker. By default they just return success via
183 // SimulateSendReplyToBrowser. 181 // SimulateSendReplyToBrowser.
184 virtual void OnActivateEvent(int embedded_worker_id, int request_id); 182 virtual void OnActivateEvent(int embedded_worker_id, int request_id);
185 virtual void OnExtendableMessageEvent( 183 virtual void OnExtendableMessageEvent(
186 mojom::ExtendableMessageEventPtr event, 184 mojom::ExtendableMessageEventPtr event,
187 const mojom::ServiceWorkerEventDispatcher:: 185 const mojom::ServiceWorkerEventDispatcher::
188 DispatchExtendableMessageEventCallback& callback); 186 DispatchExtendableMessageEventCallback& callback);
189 virtual void OnInstallEvent(int embedded_worker_id, int request_id); 187 virtual void OnInstallEvent(int embedded_worker_id, int request_id);
(...skipping 16 matching lines...) Expand all
206 void SimulateWorkerStarted(int embedded_worker_id); 204 void SimulateWorkerStarted(int embedded_worker_id);
207 void SimulateWorkerStopped(int embedded_worker_id); 205 void SimulateWorkerStopped(int embedded_worker_id);
208 void SimulateSend(IPC::Message* message); 206 void SimulateSend(IPC::Message* message);
209 207
210 EmbeddedWorkerRegistry* registry(); 208 EmbeddedWorkerRegistry* registry();
211 209
212 private: 210 private:
213 class MockEmbeddedWorkerSetup; 211 class MockEmbeddedWorkerSetup;
214 class MockServiceWorkerEventDispatcher; 212 class MockServiceWorkerEventDispatcher;
215 213
216 void OnStartWorkerStub(const EmbeddedWorkerStartParams& params); 214 void OnStartWorkerStub(const EmbeddedWorkerStartParams& params,
215 mojom::ServiceWorkerEventDispatcherRequest request);
217 void OnResumeAfterDownloadStub(int embedded_worker_id); 216 void OnResumeAfterDownloadStub(int embedded_worker_id);
218 void OnStopWorkerStub(int embedded_worker_id); 217 void OnStopWorkerStub(
218 const mojom::EmbeddedWorkerInstanceClient::StopWorkerCallback& callback);
219 void OnMessageToWorkerStub(int thread_id, 219 void OnMessageToWorkerStub(int thread_id,
220 int embedded_worker_id, 220 int embedded_worker_id,
221 const IPC::Message& message); 221 const IPC::Message& message);
222 void OnActivateEventStub(int request_id); 222 void OnActivateEventStub(int request_id);
223 void OnExtendableMessageEventStub( 223 void OnExtendableMessageEventStub(
224 mojom::ExtendableMessageEventPtr event, 224 mojom::ExtendableMessageEventPtr event,
225 const mojom::ServiceWorkerEventDispatcher:: 225 const mojom::ServiceWorkerEventDispatcher::
226 DispatchExtendableMessageEventCallback& callback); 226 DispatchExtendableMessageEventCallback& callback);
227 void OnInstallEventStub(int request_id); 227 void OnInstallEventStub(int request_id);
228 void OnFetchEventStub(int thread_id, 228 void OnFetchEventStub(int thread_id,
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after
280 std::unique_ptr<MockType> mock = 280 std::unique_ptr<MockType> mock =
281 base::MakeUnique<MockType>(std::forward<Args>(args)...); 281 base::MakeUnique<MockType>(std::forward<Args>(args)...);
282 MockType* mock_rawptr = mock.get(); 282 MockType* mock_rawptr = mock.get();
283 RegisterMockInstanceClient(std::move(mock)); 283 RegisterMockInstanceClient(std::move(mock));
284 return mock_rawptr; 284 return mock_rawptr;
285 } 285 }
286 286
287 } // namespace content 287 } // namespace content
288 288
289 #endif // CONTENT_BROWSER_SERVICE_WORKER_EMBEDDED_WORKER_TEST_HELPER_H_ 289 #endif // CONTENT_BROWSER_SERVICE_WORKER_EMBEDDED_WORKER_TEST_HELPER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698