| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  | /** | 
					
						
							|  |  |  |  * @license | 
					
						
							|  |  |  |  * Copyright Google Inc. All Rights Reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Use of this source code is governed by an MIT-style license that can be | 
					
						
							|  |  |  |  * found in the LICENSE file at https://angular.io/license
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-27 17:18:21 -08:00
										 |  |  | import {NgswCommChannel} from '@angular/service-worker/src/low_level'; | 
					
						
							|  |  |  | import {SwPush} from '@angular/service-worker/src/push'; | 
					
						
							|  |  |  | import {SwUpdate} from '@angular/service-worker/src/update'; | 
					
						
							|  |  |  | import {MockServiceWorkerContainer, MockServiceWorkerRegistration} from '@angular/service-worker/testing/mock'; | 
					
						
							|  |  |  | import {CacheDatabase} from '@angular/service-worker/worker/src/db-cache'; | 
					
						
							|  |  |  | import {Driver} from '@angular/service-worker/worker/src/driver'; | 
					
						
							|  |  |  | import {Manifest} from '@angular/service-worker/worker/src/manifest'; | 
					
						
							|  |  |  | import {MockRequest} from '@angular/service-worker/worker/testing/fetch'; | 
					
						
							|  |  |  | import {MockFileSystemBuilder, MockServerStateBuilder, tmpHashTableForFs} from '@angular/service-worker/worker/testing/mock'; | 
					
						
							|  |  |  | import {SwTestHarness, SwTestHarnessBuilder} from '@angular/service-worker/worker/testing/scope'; | 
					
						
							| 
									
										
										
										
											2018-02-27 17:06:06 -05:00
										 |  |  | import {Observable} from 'rxjs'; | 
					
						
							|  |  |  | import {take} from 'rxjs/operators'; | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-20 23:29:14 +02:00
										 |  |  | (function() { | 
					
						
							|  |  |  |   // Skip environments that don't support the minimum APIs needed to run the SW tests.
 | 
					
						
							|  |  |  |   if (!SwTestHarness.envIsSupported()) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-20 23:29:14 +02:00
										 |  |  |   const dist = new MockFileSystemBuilder().addFile('/only.txt', 'this is only').build(); | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-20 23:29:14 +02:00
										 |  |  |   const distUpdate = new MockFileSystemBuilder().addFile('/only.txt', 'this is only v2').build(); | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-20 23:29:14 +02:00
										 |  |  |   function obsToSinglePromise<T>(obs: Observable<T>): Promise<T> { | 
					
						
							|  |  |  |     return obs.pipe(take(1)).toPromise(); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-20 23:29:14 +02:00
										 |  |  |   const manifest: Manifest = { | 
					
						
							|  |  |  |     configVersion: 1, | 
					
						
							|  |  |  |     timestamp: 1234567890123, | 
					
						
							|  |  |  |     appData: {version: '1'}, | 
					
						
							|  |  |  |     index: '/only.txt', | 
					
						
							|  |  |  |     assetGroups: [{ | 
					
						
							|  |  |  |       name: 'assets', | 
					
						
							|  |  |  |       installMode: 'prefetch', | 
					
						
							|  |  |  |       updateMode: 'prefetch', | 
					
						
							|  |  |  |       urls: ['/only.txt'], | 
					
						
							|  |  |  |       patterns: [], | 
					
						
							|  |  |  |     }], | 
					
						
							|  |  |  |     navigationUrls: [], | 
					
						
							|  |  |  |     hashTable: tmpHashTableForFs(dist), | 
					
						
							|  |  |  |   }; | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-20 23:29:14 +02:00
										 |  |  |   const manifestUpdate: Manifest = { | 
					
						
							|  |  |  |     configVersion: 1, | 
					
						
							|  |  |  |     timestamp: 1234567890123, | 
					
						
							|  |  |  |     appData: {version: '2'}, | 
					
						
							|  |  |  |     index: '/only.txt', | 
					
						
							|  |  |  |     assetGroups: [{ | 
					
						
							|  |  |  |       name: 'assets', | 
					
						
							|  |  |  |       installMode: 'prefetch', | 
					
						
							|  |  |  |       updateMode: 'prefetch', | 
					
						
							|  |  |  |       urls: ['/only.txt'], | 
					
						
							|  |  |  |       patterns: [], | 
					
						
							|  |  |  |     }], | 
					
						
							|  |  |  |     navigationUrls: [], | 
					
						
							|  |  |  |     hashTable: tmpHashTableForFs(distUpdate), | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const server = new MockServerStateBuilder().withStaticFiles(dist).withManifest(manifest).build(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const serverUpdate = | 
					
						
							|  |  |  |       new MockServerStateBuilder().withStaticFiles(distUpdate).withManifest(manifestUpdate).build(); | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('ngsw + companion lib', () => { | 
					
						
							|  |  |  |     let mock: MockServiceWorkerContainer; | 
					
						
							|  |  |  |     let comm: NgswCommChannel; | 
					
						
							|  |  |  |     let reg: MockServiceWorkerRegistration; | 
					
						
							|  |  |  |     let scope: SwTestHarness; | 
					
						
							|  |  |  |     let driver: Driver; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-24 15:04:07 +03:00
										 |  |  |     beforeEach(async() => { | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  |       // Fire up the client.
 | 
					
						
							|  |  |  |       mock = new MockServiceWorkerContainer(); | 
					
						
							| 
									
										
										
										
											2018-05-10 00:11:43 +09:00
										 |  |  |       comm = new NgswCommChannel(mock as any); | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  |       scope = new SwTestHarnessBuilder().withServerState(server).build(); | 
					
						
							|  |  |  |       driver = new Driver(scope, scope, new CacheDatabase(scope, scope)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       scope.clients.add('default'); | 
					
						
							| 
									
										
										
										
											2017-10-26 10:29:36 -07:00
										 |  |  |       scope.clients.getMock('default') !.queue.subscribe(msg => { mock.sendMessage(msg); }); | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |       mock.messages.subscribe(msg => { scope.handleMessage(msg, 'default'); }); | 
					
						
							| 
									
										
										
										
											2019-07-17 17:49:16 -07:00
										 |  |  |       mock.notificationClicks.subscribe((msg: Object) => { scope.handleMessage(msg, 'default'); }); | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |       mock.setupSw(); | 
					
						
							| 
									
										
										
										
											2018-05-28 16:27:07 +03:00
										 |  |  |       reg = mock.mockRegistration !; | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |       await Promise.all(scope.handleFetch(new MockRequest('/only.txt'), 'default')); | 
					
						
							|  |  |  |       await driver.initialized; | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-24 15:04:07 +03:00
										 |  |  |     it('communicates back and forth via update check', async() => { | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  |       const update = new SwUpdate(comm); | 
					
						
							|  |  |  |       await update.checkForUpdate(); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-24 15:04:07 +03:00
										 |  |  |     it('detects an actual update', async() => { | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  |       const update = new SwUpdate(comm); | 
					
						
							|  |  |  |       scope.updateServerState(serverUpdate); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const gotUpdateNotice = | 
					
						
							|  |  |  |           (async() => { const notice = await obsToSinglePromise(update.available); })(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       await update.checkForUpdate(); | 
					
						
							|  |  |  |       await gotUpdateNotice; | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-24 15:04:07 +03:00
										 |  |  |     it('receives push message notifications', async() => { | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  |       const push = new SwPush(comm); | 
					
						
							|  |  |  |       scope.updateServerState(serverUpdate); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const gotPushNotice = (async() => { | 
					
						
							|  |  |  |         const message = await obsToSinglePromise(push.messages); | 
					
						
							|  |  |  |         expect(message).toEqual({ | 
					
						
							|  |  |  |           test: 'success', | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       })(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       await scope.handlePush({ | 
					
						
							|  |  |  |         test: 'success', | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       await gotPushNotice; | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2018-09-07 14:56:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-24 15:04:07 +03:00
										 |  |  |     it('receives push message click events', async() => { | 
					
						
							| 
									
										
										
										
											2018-09-07 14:56:40 +02:00
										 |  |  |       const push = new SwPush(comm); | 
					
						
							|  |  |  |       scope.updateServerState(serverUpdate); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const gotNotificationClick = (async() => { | 
					
						
							| 
									
										
										
										
											2018-09-28 10:28:53 +02:00
										 |  |  |         const event: any = await obsToSinglePromise(push.notificationClicks); | 
					
						
							| 
									
										
										
										
											2018-09-21 11:09:44 +02:00
										 |  |  |         expect(event.action).toEqual('clicked'); | 
					
						
							|  |  |  |         expect(event.notification.title).toEqual('This is a test'); | 
					
						
							| 
									
										
										
										
											2018-09-07 14:56:40 +02:00
										 |  |  |       })(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 11:09:44 +02:00
										 |  |  |       await scope.handleClick({title: 'This is a test'}, 'clicked'); | 
					
						
							| 
									
										
										
										
											2018-09-07 14:56:40 +02:00
										 |  |  |       await gotNotificationClick; | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2017-09-28 16:18:12 -07:00
										 |  |  |   }); | 
					
						
							| 
									
										
										
										
											2019-06-24 15:04:07 +03:00
										 |  |  | })(); |