| 
									
										
										
										
											2017-12-01 14:23:03 -08: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
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-17 18:49:21 -07:00
										 |  |  | import {ɵɵdefineComponent} from '../../src/render3/index'; | 
					
						
							|  |  |  | import {ɵɵcontainer, ɵɵcontainerRefreshEnd, ɵɵcontainerRefreshStart, ɵɵelementEnd, ɵɵelementStart, ɵɵembeddedViewEnd, ɵɵembeddedViewStart, ɵɵtext} from '../../src/render3/instructions/all'; | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  | import {RenderFlags} from '../../src/render3/interfaces/definition'; | 
					
						
							| 
									
										
										
										
											2019-04-04 11:41:52 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  | import {document, renderComponent} from './render_util'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | describe('iv perf test', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const count = 100000; | 
					
						
							|  |  |  |   const noOfIterations = 10; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('render', () => { | 
					
						
							|  |  |  |     for (let iteration = 0; iteration < noOfIterations; iteration++) { | 
					
						
							|  |  |  |       it(`${iteration}. create ${count} divs in DOM`, () => { | 
					
						
							|  |  |  |         const start = new Date().getTime(); | 
					
						
							|  |  |  |         const container = document.createElement('div'); | 
					
						
							|  |  |  |         for (let i = 0; i < count; i++) { | 
					
						
							|  |  |  |           const div = document.createElement('div'); | 
					
						
							|  |  |  |           div.appendChild(document.createTextNode('-')); | 
					
						
							|  |  |  |           container.appendChild(div); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         const end = new Date().getTime(); | 
					
						
							|  |  |  |         log(`${count} DIVs in DOM`, (end - start) / count); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it(`${iteration}. create ${count} divs in Render3`, () => { | 
					
						
							|  |  |  |         class Component { | 
					
						
							| 
									
										
										
										
											2019-10-11 14:18:45 -07:00
										 |  |  |           static ɵfac = () => new Component; | 
					
						
							| 
									
										
										
										
											2019-10-10 14:57:15 -07:00
										 |  |  |           static ɵcmp = ɵɵdefineComponent({ | 
					
						
							| 
									
										
										
										
											2018-01-22 15:27:21 -08:00
										 |  |  |             type: Component, | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |             selectors: [['div']], | 
					
						
							| 
									
										
										
										
											2019-09-23 20:08:51 +02:00
										 |  |  |             decls: 1, | 
					
						
							| 
									
										
										
										
											2018-08-18 11:14:50 -07:00
										 |  |  |             vars: 0, | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |             template: function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |               if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2019-05-17 18:49:21 -07:00
										 |  |  |                 ɵɵcontainer(0); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |               } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |               if (rf & RenderFlags.Update) { | 
					
						
							| 
									
										
										
										
											2019-05-17 18:49:21 -07:00
										 |  |  |                 ɵɵcontainerRefreshStart(0); | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |                 { | 
					
						
							|  |  |  |                   for (let i = 0; i < count; i++) { | 
					
						
							| 
									
										
										
										
											2019-05-17 18:49:21 -07:00
										 |  |  |                     let rf0 = ɵɵembeddedViewStart(0, 2, 0); | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |                     { | 
					
						
							|  |  |  |                       if (rf0 & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2019-05-17 18:49:21 -07:00
										 |  |  |                         ɵɵelementStart(0, 'div'); | 
					
						
							|  |  |  |                         ɵɵtext(1, '-'); | 
					
						
							|  |  |  |                         ɵɵelementEnd(); | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |                       } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |                     } | 
					
						
							| 
									
										
										
										
											2019-05-17 18:49:21 -07:00
										 |  |  |                     ɵɵembeddedViewEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |                   } | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2019-05-17 18:49:21 -07:00
										 |  |  |                 ɵɵcontainerRefreshEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |               } | 
					
						
							| 
									
										
										
										
											2019-08-12 09:26:20 +03:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           }); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const start = new Date().getTime(); | 
					
						
							|  |  |  |         renderComponent(Component); | 
					
						
							|  |  |  |         const end = new Date().getTime(); | 
					
						
							|  |  |  |         log(`${count} DIVs in Render3`, (end - start) / count); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function log(text: string, duration: number) { | 
					
						
							|  |  |  |   // tslint:disable-next-line:no-console
 | 
					
						
							|  |  |  |   console.log(text, duration * 1000, 'ns'); | 
					
						
							|  |  |  | } |