fix(service-worker): use relative path for ngsw.json

Not every application is served from the domain root. The Service
Worker made a bad assumption that it would be, and so requested
/ngsw.json from the domain root.

This change corrects this assumption, and requests ngsw.json without
the leading slash. This causes the request to be interpreted
relative to the SW origin, which will be the application root.
This commit is contained in:
Alex Rickabaugh 2017-11-30 09:51:09 -08:00
parent 3fbcde9048
commit f582620d5b
3 changed files with 8 additions and 8 deletions

View File

@ -580,8 +580,8 @@ export class Driver implements Debuggable, UpdateSource {
* Retrieve a copy of the latest manifest from the server. * Retrieve a copy of the latest manifest from the server.
*/ */
private async fetchLatestManifest(): Promise<Manifest> { private async fetchLatestManifest(): Promise<Manifest> {
const res = await this.safeFetch( const res =
this.adapter.newRequest('/ngsw.json?ngsw-cache-bust=' + Math.random())); await this.safeFetch(this.adapter.newRequest('ngsw.json?ngsw-cache-bust=' + Math.random()));
if (!res.ok) { if (!res.ok) {
if (res.status === 404) { if (res.status === 404) {
await this.deleteAllCaches(); await this.deleteAllCaches();

View File

@ -158,7 +158,7 @@ export function main() {
expect(await scope.startup(true)).toEqual(true); expect(await scope.startup(true)).toEqual(true);
await scope.resolveSelfMessages(); await scope.resolveSelfMessages();
await driver.initialized; await driver.initialized;
server.assertSawRequestFor('/ngsw.json'); server.assertSawRequestFor('ngsw.json');
server.assertSawRequestFor('/foo.txt'); server.assertSawRequestFor('/foo.txt');
server.assertSawRequestFor('/bar.txt'); server.assertSawRequestFor('/bar.txt');
server.assertSawRequestFor('/redirected.txt'); server.assertSawRequestFor('/redirected.txt');
@ -170,7 +170,7 @@ export function main() {
async_it('initializes prefetched content correctly, after a request kicks it off', async() => { async_it('initializes prefetched content correctly, after a request kicks it off', async() => {
expect(await makeRequest(scope, '/foo.txt')).toEqual('this is foo'); expect(await makeRequest(scope, '/foo.txt')).toEqual('this is foo');
await driver.initialized; await driver.initialized;
server.assertSawRequestFor('/ngsw.json'); server.assertSawRequestFor('ngsw.json');
server.assertSawRequestFor('/foo.txt'); server.assertSawRequestFor('/foo.txt');
server.assertSawRequestFor('/bar.txt'); server.assertSawRequestFor('/bar.txt');
server.assertSawRequestFor('/redirected.txt'); server.assertSawRequestFor('/redirected.txt');
@ -230,7 +230,7 @@ export function main() {
scope.updateServerState(serverUpdate); scope.updateServerState(serverUpdate);
expect(await driver.checkForUpdate()).toEqual(true); expect(await driver.checkForUpdate()).toEqual(true);
serverUpdate.assertSawRequestFor('/ngsw.json'); serverUpdate.assertSawRequestFor('ngsw.json');
serverUpdate.assertSawRequestFor('/foo.txt'); serverUpdate.assertSawRequestFor('/foo.txt');
serverUpdate.assertSawRequestFor('/redirected.txt'); serverUpdate.assertSawRequestFor('/redirected.txt');
serverUpdate.assertNoOtherRequests(); serverUpdate.assertNoOtherRequests();
@ -263,7 +263,7 @@ export function main() {
scope.updateServerState(serverUpdate); scope.updateServerState(serverUpdate);
expect(await driver.checkForUpdate()).toEqual(true); expect(await driver.checkForUpdate()).toEqual(true);
serverUpdate.assertSawRequestFor('/ngsw.json'); serverUpdate.assertSawRequestFor('ngsw.json');
serverUpdate.assertSawRequestFor('/foo.txt'); serverUpdate.assertSawRequestFor('/foo.txt');
serverUpdate.assertSawRequestFor('/redirected.txt'); serverUpdate.assertSawRequestFor('/redirected.txt');
serverUpdate.assertNoOtherRequests(); serverUpdate.assertNoOtherRequests();
@ -331,7 +331,7 @@ export function main() {
scope.advance(12000); scope.advance(12000);
await driver.idle.empty; await driver.idle.empty;
serverUpdate.assertSawRequestFor('/ngsw.json'); serverUpdate.assertSawRequestFor('ngsw.json');
serverUpdate.assertSawRequestFor('/foo.txt'); serverUpdate.assertSawRequestFor('/foo.txt');
serverUpdate.assertSawRequestFor('/redirected.txt'); serverUpdate.assertSawRequestFor('/redirected.txt');
serverUpdate.assertNoOtherRequests(); serverUpdate.assertNoOtherRequests();

View File

@ -73,7 +73,7 @@ export class MockServerStateBuilder {
} }
withManifest(manifest: Manifest): MockServerStateBuilder { withManifest(manifest: Manifest): MockServerStateBuilder {
this.resources.set('/ngsw.json', new MockResponse(JSON.stringify(manifest))); this.resources.set('ngsw.json', new MockResponse(JSON.stringify(manifest)));
return this; return this;
} }