Bug 261767

Summary: REGRESSION (iOS 17): PWA startup "FetchEvent.respondWith received an error TypeError: Internal error"
Product: WebKit Reporter: Jesper Bendtsen <jesperbendtsen83>
Component: Service WorkersAssignee: youenn fablet <youennf>
Status: RESOLVED FIXED    
Severity: Critical CC: achristensen, annevk, beidson, cdumez, kyro38, michael.hagar, niels, webkit-bug-importer, youennf
Priority: P2 Keywords: InRadar
Version: Safari 17   
Hardware: iPhone / iPad   
OS: Other   
Attachments:
Description Flags
Screenshot none

Jesper Bendtsen
Reported 2023-09-19 13:10:38 PDT
Created attachment 467765 [details] Screenshot After update to iOS 17, PWA fails at startup. Video, screenshot, diagnose log and access to test env are added to this feedback: https://feedbackassistant.apple.com/feedback/13188943 Please help, it is very bad for my organization...
Attachments
Screenshot (103.06 KB, image/jpeg)
2023-09-19 13:10 PDT, Jesper Bendtsen
no flags
Radar WebKit Bug Importer
Comment 1 2023-09-19 14:44:09 PDT
Alexey Proskuryakov
Comment 2 2023-09-19 14:44:21 PDT
Jesper Bendtsen
Comment 3 2023-09-20 22:03:48 PDT
The error happens on both iPad iOS 17 and iPhone iOS 17
Jesper Bendtsen
Comment 4 2023-09-25 11:45:39 PDT
Matthieu Riegler
Comment 5 2023-09-25 11:49:00 PDT
OSS Angular contributor here, I can provide some insights. The error has been reported first on the framework repo : https://github.com/angular/angular/issues/50378 The issue can be narrowed down to a call `caches.match` that throws a "TypeError: Internal error" The error OP is reporting is because that error wasn't catched and `FetchEvent.respondWith` failed. I believe the root cause is still on Safari's side with the internal error being thrown by the method call mentioned above. Related workaround PR on Angular's side : https://github.com/angular/angular/pull/51885/files
youenn fablet
Comment 6 2023-09-26 03:08:51 PDT
youenn fablet
Comment 7 2023-09-26 09:30:48 PDT
There are several potential issues that can lead to the Internal error case. One of the main issues can probably be worked around by calling self.caches.open() (and then match) instead of doing self.caches.match().
Michael Hagar
Comment 9 2023-09-27 05:58:00 PDT
I'm seeing a similar error on Desktop Safari 17 for our PWA that is using a service worker to cache JS assets. The fetch fails with "Failed to load resource: FetchEvent.respondWith received an error: no-response: no-response :: [{"url":"<url>", "error":{}}]
EWS
Comment 10 2023-09-27 23:52:29 PDT
Committed 268565@main (dd68eb88a64c): <https://commits.webkit.org/268565@main> Reviewed commits have been landed. Closing PR #18217 and removing active labels.
Note You need to log in before you can comment on or make changes to this bug.