| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Copyright 2017 Google Inc. All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Licensed under the Apache License, Version 2.0 (the "License"); | 
					
						
							|  |  |  |  * you may not use this file except in compliance with the License. | 
					
						
							|  |  |  |  * You may obtain a copy of the License at | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *     http://www.apache.org/licenses/LICENSE-2.0
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Unless required by applicable law or agreed to in writing, software | 
					
						
							|  |  |  |  * distributed under the License is distributed on an "AS IS" BASIS, | 
					
						
							|  |  |  |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
					
						
							|  |  |  |  * See the License for the specific language governing permissions and | 
					
						
							|  |  |  |  * limitations under the License. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const path = require('path'); | 
					
						
							|  |  |  | const playwright = require('../../../..'); | 
					
						
							|  |  |  | const checkPublicAPI = require('..'); | 
					
						
							|  |  |  | const Source = require('../../Source'); | 
					
						
							|  |  |  | const mdBuilder = require('../MDBuilder'); | 
					
						
							|  |  |  | const jsBuilder = require('../JSBuilder'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-06 17:21:42 -07:00
										 |  |  | const TestRunner  = require('../../../testrunner/'); | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  | const runner = new TestRunner(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-06 17:21:42 -07:00
										 |  |  | const {describe, xdescribe, fdescribe} = runner.api(); | 
					
						
							|  |  |  | const {it, fit, xit} = runner.api(); | 
					
						
							|  |  |  | const {beforeAll, beforeEach, afterAll, afterEach} = runner.api(); | 
					
						
							| 
									
										
										
										
											2020-04-06 18:01:56 -07:00
										 |  |  | const {expect} = runner.api(); | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-06 17:21:42 -07:00
										 |  |  | let browser; | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  | let page; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | beforeAll(async function() { | 
					
						
							| 
									
										
										
										
											2020-02-24 18:24:02 -08:00
										 |  |  |   browser = await playwright.chromium.launch(); | 
					
						
							| 
									
										
										
										
											2020-02-05 12:41:55 -08:00
										 |  |  |   page = await browser.newPage(); | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | afterAll(async function() { | 
					
						
							|  |  |  |   await browser.close(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | describe('checkPublicAPI', function() { | 
					
						
							|  |  |  |   it('diff-classes', testLint); | 
					
						
							|  |  |  |   it('diff-methods', testLint); | 
					
						
							|  |  |  |   it('diff-properties', testLint); | 
					
						
							|  |  |  |   it('diff-arguments', testLint); | 
					
						
							|  |  |  |   it('diff-events', testLint); | 
					
						
							|  |  |  |   it('check-duplicates', testLint); | 
					
						
							|  |  |  |   it('check-sorting', testLint); | 
					
						
							|  |  |  |   it('check-returns', testLint); | 
					
						
							| 
									
										
										
										
											2020-03-18 16:23:25 -07:00
										 |  |  |   it('check-nullish', testLint); | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  |   it('js-builder-common', testJSBuilder); | 
					
						
							|  |  |  |   it('js-builder-inheritance', testJSBuilder); | 
					
						
							|  |  |  |   it('md-builder-common', testMDBuilder); | 
					
						
							| 
									
										
										
										
											2020-03-23 14:50:32 -07:00
										 |  |  |   it('md-builder-comments', testMDBuilder); | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | runner.run(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-06 17:21:42 -07:00
										 |  |  | async function testLint(state, testRun) { | 
					
						
							|  |  |  |   const dirPath = path.join(__dirname, testRun.test().name()); | 
					
						
							| 
									
										
										
										
											2020-04-06 18:01:56 -07:00
										 |  |  |   expect.setupGolden(dirPath); | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  |   const mdSources = await Source.readdir(dirPath, '.md'); | 
					
						
							| 
									
										
										
										
											2020-02-24 18:24:02 -08:00
										 |  |  |   const tsSources = await Source.readdir(dirPath, '.ts'); | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  |   const jsSources = await Source.readdir(dirPath, '.js'); | 
					
						
							| 
									
										
										
										
											2020-02-24 18:24:02 -08:00
										 |  |  |   const messages = await checkPublicAPI(page, mdSources, jsSources.concat(tsSources)); | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  |   const errors = messages.map(message => message.text); | 
					
						
							|  |  |  |   expect(errors.join('\n')).toBeGolden('result.txt'); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-06 17:21:42 -07:00
										 |  |  | async function testMDBuilder(state, testRun) { | 
					
						
							|  |  |  |   const dirPath = path.join(__dirname, testRun.test().name()); | 
					
						
							| 
									
										
										
										
											2020-04-06 18:01:56 -07:00
										 |  |  |   expect.setupGolden(dirPath); | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  |   const sources = await Source.readdir(dirPath, '.md'); | 
					
						
							|  |  |  |   const {documentation} = await mdBuilder(page, sources); | 
					
						
							|  |  |  |   expect(serialize(documentation)).toBeGolden('result.txt'); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-06 17:21:42 -07:00
										 |  |  | async function testJSBuilder(state, testRun) { | 
					
						
							|  |  |  |   const dirPath = path.join(__dirname, testRun.test().name()); | 
					
						
							| 
									
										
										
										
											2020-04-06 18:01:56 -07:00
										 |  |  |   expect.setupGolden(dirPath); | 
					
						
							| 
									
										
										
										
											2020-02-24 18:24:02 -08:00
										 |  |  |   const jsSources = await Source.readdir(dirPath, '.js'); | 
					
						
							|  |  |  |   const tsSources = await Source.readdir(dirPath, '.ts'); | 
					
						
							|  |  |  |   const {documentation} = await jsBuilder.checkSources(jsSources.concat(tsSources)); | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  |   expect(serialize(documentation)).toBeGolden('result.txt'); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @param {import('../Documentation')} doc | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | function serialize(doc) { | 
					
						
							|  |  |  |   const result = { | 
					
						
							|  |  |  |     classes: doc.classesArray.map(cls => ({ | 
					
						
							|  |  |  |       name: cls.name, | 
					
						
							| 
									
										
										
										
											2020-03-23 14:50:32 -07:00
										 |  |  |       comment: cls.comment || undefined, | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  |       members: cls.membersArray.map(serializeMember) | 
					
						
							|  |  |  |     })) | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   return JSON.stringify(result, null, 2); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @param {import('../Documentation').Member} member | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | function serializeMember(member) { | 
					
						
							|  |  |  |   return { | 
					
						
							|  |  |  |     name: member.name, | 
					
						
							|  |  |  |     type: serializeType(member.type), | 
					
						
							|  |  |  |     kind: member.kind, | 
					
						
							| 
									
										
										
										
											2020-03-23 14:50:32 -07:00
										 |  |  |     comment: member.comment || undefined, | 
					
						
							| 
									
										
										
										
											2019-11-18 18:18:28 -08:00
										 |  |  |     args: member.argsArray.length ? member.argsArray.map(serializeMember) : undefined | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @param {import('../Documentation').Type} type | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | function serializeType(type) { | 
					
						
							|  |  |  |   if (!type) | 
					
						
							|  |  |  |     return undefined; | 
					
						
							|  |  |  |   return { | 
					
						
							|  |  |  |     name: type.name, | 
					
						
							|  |  |  |     properties: type.properties.length ? type.properties.map(serializeMember) : undefined | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } |