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

Issue 247263010: ServiceWorker: Wait for registration promise to resolve before changing states. (Closed)

Created:
6 years, 8 months ago by falken
Modified:
6 years, 8 months ago
CC:
blink-reviews, Nils Barth (inactive), jsbell+serviceworker_chromium.org, sof, arv+blink, jsbell+bindings_chromium.org, marja+watch_chromium.org, tzik, serviceworker-reviews, kouhei+bindings_chromium.org, nhiroki, abarth-chromium, kinuko, falken, dglazkov+blink, jamesr, adamk+blink_chromium.org, horo+watch_chromium.org, Nate Chapin, alecflett+watch_chromium.org, Inactive
Visibility:
Public.

Description

ServiceWorker: Wait for registration promise to resolve before changing states. V8 Promise resolving is done as an async task. So resolving the ServiceWorker registration promise followed by installing and activating the worker on the browser side could result in an activated service worker visible in the JavaScript "then" method, although the worker is expected to have not yet begun installation at that point. This patch teaches ServiceWorker to wait for the registration promise to resolve before processing state changes from the browser. This patch won't have an effect until the Chromium side change also lands. BUG=365252 Committed: https://src.chromium.org/viewvc/blink?view=rev&revision=172459

Patch Set 1 #

Patch Set 2 : cleanup test #

Total comments: 6

Patch Set 3 : review comments #

Total comments: 6

Patch Set 4 : sync and add an assert #

Patch Set 5 : yhirano comments #

Total comments: 2
Unified diffs Side-by-side diffs Delta from patch set Stats (+142 lines, -21 lines) Patch
M LayoutTests/TestExpectations View 1 2 3 1 chunk +3 lines, -0 lines 0 comments Download
A LayoutTests/http/tests/serviceworker/activation-after-registration.html View 1 1 chunk +29 lines, -0 lines 0 comments Download
A LayoutTests/http/tests/serviceworker/activation-after-registration-expected.txt View 1 chunk +3 lines, -0 lines 0 comments Download
A + LayoutTests/http/tests/serviceworker/resources/worker-no-op.js View 0 chunks +-1 lines, --1 lines 0 comments Download
A LayoutTests/virtual/serviceworker/http/tests/serviceworker/activation-after-registration-expected.txt View 1 chunk +3 lines, -0 lines 0 comments Download
M Source/bindings/v8/CallbackPromiseAdapter.h View 2 chunks +12 lines, -6 lines 0 comments Download
M Source/modules/push_messaging/PushError.h View 1 chunk +2 lines, -2 lines 0 comments Download
M Source/modules/push_messaging/PushRegistration.h View 1 chunk +2 lines, -2 lines 0 comments Download
M Source/modules/serviceworkers/ServiceWorker.h View 4 chunks +11 lines, -1 line 0 comments Download
M Source/modules/serviceworkers/ServiceWorker.cpp View 1 2 3 4 5 chunks +62 lines, -3 lines 0 comments Download
M Source/modules/serviceworkers/ServiceWorkerClients.cpp View 2 chunks +1 line, -3 lines 0 comments Download
M Source/modules/serviceworkers/ServiceWorkerContainer.cpp View 1 2 3 4 1 chunk +2 lines, -2 lines 0 comments Download
M Source/modules/serviceworkers/ServiceWorkerError.h View 1 chunk +2 lines, -2 lines 0 comments Download
M public/platform/WebServiceWorker.h View 1 chunk +3 lines, -0 lines 2 comments Download
M public/platform/WebServiceWorkerProxy.h View 1 2 1 chunk +8 lines, -1 line 0 comments Download

Messages

Total messages: 15 (0 generated)
falken
kinuko, yhirano: can you please review? Chromium-side change: https://codereview.chromium.org/249143002/
6 years, 8 months ago (2014-04-23 09:44:38 UTC) #1
kinuko
ServiceWorker related part lgtm https://codereview.chromium.org/247263010/diff/20001/Source/modules/serviceworkers/ServiceWorker.cpp File Source/modules/serviceworkers/ServiceWorker.cpp (right): https://codereview.chromium.org/247263010/diff/20001/Source/modules/serviceworkers/ServiceWorker.cpp#newcode104 Source/modules/serviceworkers/ServiceWorker.cpp:104: { Can you also add ...
6 years, 8 months ago (2014-04-23 14:20:00 UTC) #2
haraken
bindings/ LGTM.
6 years, 8 months ago (2014-04-23 14:35:29 UTC) #3
falken
Thanks! +tkent: Can you review public/ please? https://codereview.chromium.org/247263010/diff/20001/Source/modules/serviceworkers/ServiceWorker.cpp File Source/modules/serviceworkers/ServiceWorker.cpp (right): https://codereview.chromium.org/247263010/diff/20001/Source/modules/serviceworkers/ServiceWorker.cpp#newcode104 Source/modules/serviceworkers/ServiceWorker.cpp:104: { On ...
6 years, 8 months ago (2014-04-24 00:58:49 UTC) #4
tkent
lgtm
6 years, 8 months ago (2014-04-24 01:24:02 UTC) #5
yhirano
https://codereview.chromium.org/247263010/diff/40001/Source/modules/serviceworkers/ServiceWorker.cpp File Source/modules/serviceworkers/ServiceWorker.cpp (right): https://codereview.chromium.org/247263010/diff/40001/Source/modules/serviceworkers/ServiceWorker.cpp#newcode156 Source/modules/serviceworkers/ServiceWorker.cpp:156: } Shouldn't we clear the queue? https://codereview.chromium.org/247263010/diff/40001/Source/modules/serviceworkers/ServiceWorker.cpp#newcode163 Source/modules/serviceworkers/ServiceWorker.cpp:163: ThenFunction::create(this, ...
6 years, 8 months ago (2014-04-24 01:53:49 UTC) #6
falken
Thanks for the review! Can you take another look? https://codereview.chromium.org/247263010/diff/40001/Source/modules/serviceworkers/ServiceWorker.cpp File Source/modules/serviceworkers/ServiceWorker.cpp (right): https://codereview.chromium.org/247263010/diff/40001/Source/modules/serviceworkers/ServiceWorker.cpp#newcode156 Source/modules/serviceworkers/ServiceWorker.cpp:156: ...
6 years, 8 months ago (2014-04-24 02:38:41 UTC) #7
yhirano
lgtm
6 years, 8 months ago (2014-04-24 03:19:13 UTC) #8
falken
The CQ bit was checked by falken@chromium.org
6 years, 8 months ago (2014-04-24 05:48:56 UTC) #9
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-status.appspot.com/cq/falken@chromium.org/247263010/80001
6 years, 8 months ago (2014-04-24 05:49:17 UTC) #10
commit-bot: I haz the power
Change committed as 172459
6 years, 8 months ago (2014-04-24 06:21:48 UTC) #11
michaeln1
https://codereview.chromium.org/247263010/diff/80001/public/platform/WebServiceWorker.h File public/platform/WebServiceWorker.h (right): https://codereview.chromium.org/247263010/diff/80001/public/platform/WebServiceWorker.h#newcode57 public/platform/WebServiceWorker.h:57: virtual void setState(blink::WebServiceWorkerState) { } This webkit api is ...
6 years, 8 months ago (2014-04-24 21:15:07 UTC) #12
falken
https://codereview.chromium.org/247263010/diff/80001/public/platform/WebServiceWorker.h File public/platform/WebServiceWorker.h (right): https://codereview.chromium.org/247263010/diff/80001/public/platform/WebServiceWorker.h#newcode57 public/platform/WebServiceWorker.h:57: virtual void setState(blink::WebServiceWorkerState) { } On 2014/04/24 21:15:08, michaeln1 ...
6 years, 8 months ago (2014-04-25 01:13:10 UTC) #13
michaeln
> Good idea, things would be clearer this way and I think it should work. ...
6 years, 8 months ago (2014-04-25 01:32:20 UTC) #14
kinuko
6 years, 8 months ago (2014-04-25 04:24:45 UTC) #15
Yeah that sounds nicer.

On Fri, Apr 25, 2014 at 10:32 AM, <michaeln@chromium.org> wrote:

> Good idea, things would be clearer this way and I think it should work.
>> I'll
>> take a stab at it and see how it turns out.
>>
>
> Wunderbar :)
>
> https://codereview.chromium.org/247263010/
>

To unsubscribe from this group and stop receiving emails from it, send an email
to blink-reviews+unsubscribe@chromium.org.

Powered by Google App Engine
This is Rietveld 408576698