| 
									
										
										
										
											2021-07-03 19:18:21 -07:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Copyright (c) Microsoft Corporation. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-25 15:05:50 -08:00
										 |  |  | import { browserTest as it, expect } from '../config/browserTest'; | 
					
						
							| 
									
										
										
										
											2021-07-03 19:18:21 -07:00
										 |  |  | import fs from 'fs'; | 
					
						
							| 
									
										
										
										
											2022-06-21 14:04:52 -07:00
										 |  |  | import os from 'os'; | 
					
						
							| 
									
										
										
										
											2021-07-03 19:18:21 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | async function checkFeatures(name: string, context: any, server: any) { | 
					
						
							|  |  |  |   try { | 
					
						
							|  |  |  |     const page = await context.newPage(); | 
					
						
							|  |  |  |     await page.goto(server.PREFIX + '/modernizr.html'); | 
					
						
							|  |  |  |     const actual = await page.evaluate('window.report'); | 
					
						
							| 
									
										
										
										
											2022-03-25 21:11:29 -08:00
										 |  |  |     const expected = JSON.parse(fs.readFileSync(require.resolve(`../assets/modernizr/${name}.json`), 'utf-8')); | 
					
						
							| 
									
										
										
										
											2021-07-23 09:13:57 -07:00
										 |  |  |     return { actual, expected }; | 
					
						
							| 
									
										
										
										
											2021-07-03 19:18:21 -07:00
										 |  |  |   } finally { | 
					
						
							|  |  |  |     await context.close(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-03 14:51:11 -07:00
										 |  |  | it('safari-14-1', async ({ browser, browserName, platform, server, headless, isMac }) => { | 
					
						
							| 
									
										
										
										
											2021-07-23 09:13:57 -07:00
										 |  |  |   it.skip(browserName !== 'webkit'); | 
					
						
							| 
									
										
										
										
											2022-06-21 14:04:52 -07:00
										 |  |  |   it.skip(browserName === 'webkit' && parseInt(os.release(), 10) < 20, 'WebKit for macOS 10.15 is frozen.'); | 
					
						
							| 
									
										
										
										
											2021-07-12 08:35:59 -07:00
										 |  |  |   const context = await browser.newContext({ | 
					
						
							|  |  |  |     deviceScaleFactor: 2 | 
					
						
							|  |  |  |   }); | 
					
						
							| 
									
										
										
										
											2021-07-23 09:13:57 -07:00
										 |  |  |   const { actual, expected } = await checkFeatures('safari-14-1', context, server); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (platform === 'linux') { | 
					
						
							|  |  |  |     expected.subpixelfont = false; | 
					
						
							|  |  |  |     if (headless) | 
					
						
							|  |  |  |       expected.todataurljpeg = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // GHA
 | 
					
						
							|  |  |  |     delete actual.variablefonts; | 
					
						
							|  |  |  |     delete expected.variablefonts; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (isDocker()) { | 
					
						
							|  |  |  |       delete actual.unicode; | 
					
						
							|  |  |  |       delete expected.unicode; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (platform === 'win32') { | 
					
						
							|  |  |  |     expected.datalistelem = false; | 
					
						
							|  |  |  |     expected.fileinputdirectory = false; | 
					
						
							|  |  |  |     expected.getusermedia = false; | 
					
						
							|  |  |  |     expected.peerconnection = false; | 
					
						
							|  |  |  |     expected.speechrecognition = false; | 
					
						
							|  |  |  |     expected.speechsynthesis = false; | 
					
						
							|  |  |  |     expected.todataurljpeg = false; | 
					
						
							|  |  |  |     expected.unicode = false; | 
					
						
							|  |  |  |     expected.webaudio = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     expected.input.list = false; | 
					
						
							|  |  |  |     expected.inputtypes.color = false; | 
					
						
							|  |  |  |     expected.inputtypes.date = false; | 
					
						
							|  |  |  |     expected.inputtypes['datetime-local'] = false; | 
					
						
							|  |  |  |     expected.inputtypes.time = false; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2022-08-03 14:51:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-19 09:24:21 -07:00
										 |  |  |   if (isMac && parseInt(os.release(), 10) > 20) { | 
					
						
							| 
									
										
										
										
											2022-08-03 14:51:11 -07:00
										 |  |  |     expected.applicationcache = false; | 
					
						
							| 
									
										
										
										
											2023-07-19 09:24:21 -07:00
										 |  |  |     expected.inputsearchevent = false; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2022-08-03 14:51:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-23 09:13:57 -07:00
										 |  |  |   expect(actual).toEqual(expected); | 
					
						
							| 
									
										
										
										
											2021-07-03 19:18:21 -07:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-03 14:51:11 -07:00
										 |  |  | it('mobile-safari-14-1', async ({ playwright, browser, browserName, platform, isMac, server, headless }) => { | 
					
						
							| 
									
										
										
										
											2021-07-23 09:13:57 -07:00
										 |  |  |   it.skip(browserName !== 'webkit'); | 
					
						
							| 
									
										
										
										
											2022-06-21 14:04:52 -07:00
										 |  |  |   it.skip(browserName === 'webkit' && parseInt(os.release(), 10) < 20, 'WebKit for macOS 10.15 is frozen.'); | 
					
						
							| 
									
										
										
										
											2021-07-03 19:18:21 -07:00
										 |  |  |   const iPhone = playwright.devices['iPhone 12']; | 
					
						
							|  |  |  |   const context = await browser.newContext(iPhone); | 
					
						
							| 
									
										
										
										
											2021-07-23 09:13:57 -07:00
										 |  |  |   const { actual, expected } = await checkFeatures('mobile-safari-14-1', context, server); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     // All platforms.
 | 
					
						
							|  |  |  |     expected.capture = false; | 
					
						
							|  |  |  |     expected.cssscrollbar = true; | 
					
						
							|  |  |  |     expected.cssvhunit = true; | 
					
						
							|  |  |  |     expected.cssvmaxunit = true; | 
					
						
							|  |  |  |     expected.overflowscrolling = false; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (platform === 'linux') { | 
					
						
							|  |  |  |     expected.subpixelfont = false; | 
					
						
							|  |  |  |     if (headless) | 
					
						
							|  |  |  |       expected.todataurljpeg = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // GHA
 | 
					
						
							|  |  |  |     delete actual.variablefonts; | 
					
						
							|  |  |  |     delete expected.variablefonts; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (isDocker()) { | 
					
						
							|  |  |  |       delete actual.unicode; | 
					
						
							|  |  |  |       delete expected.unicode; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (platform === 'win32') { | 
					
						
							|  |  |  |     expected.datalistelem = false; | 
					
						
							|  |  |  |     expected.fileinputdirectory = false; | 
					
						
							|  |  |  |     expected.getusermedia = false; | 
					
						
							|  |  |  |     expected.peerconnection = false; | 
					
						
							|  |  |  |     expected.speechrecognition = false; | 
					
						
							|  |  |  |     expected.speechsynthesis = false; | 
					
						
							|  |  |  |     expected.todataurljpeg = false; | 
					
						
							|  |  |  |     expected.unicode = false; | 
					
						
							|  |  |  |     expected.webaudio = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     expected.input.list = false; | 
					
						
							|  |  |  |     expected.inputtypes.color = false; | 
					
						
							|  |  |  |     expected.inputtypes.month = false; | 
					
						
							|  |  |  |     expected.inputtypes.week = false; | 
					
						
							|  |  |  |     expected.inputtypes.date = false; | 
					
						
							|  |  |  |     expected.inputtypes.time = false; | 
					
						
							|  |  |  |     expected.inputtypes['datetime-local'] = false; | 
					
						
							|  |  |  |     expected.inputtypes.time = false; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-19 09:24:21 -07:00
										 |  |  |   if (isMac && parseInt(os.release(), 10) > 20) { | 
					
						
							| 
									
										
										
										
											2022-08-03 14:51:11 -07:00
										 |  |  |     expected.applicationcache = false; | 
					
						
							| 
									
										
										
										
											2023-07-19 09:24:21 -07:00
										 |  |  |     expected.inputsearchevent = false; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2022-08-03 14:51:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-23 09:13:57 -07:00
										 |  |  |   expect(actual).toEqual(expected); | 
					
						
							| 
									
										
										
										
											2021-07-03 19:18:21 -07:00
										 |  |  | }); | 
					
						
							| 
									
										
										
										
											2021-07-23 09:13:57 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | function isDocker() { | 
					
						
							|  |  |  |   try { | 
					
						
							|  |  |  |     fs.statSync('/.dockerenv'); | 
					
						
							|  |  |  |     return true; | 
					
						
							|  |  |  |   } catch { | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   try { | 
					
						
							|  |  |  |     return fs.readFileSync('/proc/self/cgroup', 'utf8').includes('docker'); | 
					
						
							|  |  |  |   } catch { | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return false; | 
					
						
							|  |  |  | } |