@wdio/image-comparison-core 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +82 -0
- package/LICENSE +21 -0
- package/README.md +12 -0
- package/assets/ios/ipadair4th.ipadair5th-bottom.png +0 -0
- package/assets/ios/ipadair4th.ipadair5th-top.png +0 -0
- package/assets/ios/ipadmini6th-bottom.png +0 -0
- package/assets/ios/ipadmini6th-top.png +0 -0
- package/assets/ios/ipadpro11-bottom.png +0 -0
- package/assets/ios/ipadpro11-top.png +0 -0
- package/assets/ios/ipadpro129-bottom.png +0 -0
- package/assets/ios/ipadpro129-top.png +0 -0
- package/assets/ios/iphone11promax-bottom.png +0 -0
- package/assets/ios/iphone11promax-top.png +0 -0
- package/assets/ios/iphone12.iphone12pro-top.png +0 -0
- package/assets/ios/iphone12.iphone12pro.iphone13.iphone13pro.iphone14-bottom.png +0 -0
- package/assets/ios/iphone12mini-top.png +0 -0
- package/assets/ios/iphone12mini.iphone13mini-bottom.png +0 -0
- package/assets/ios/iphone12promax-top.png +0 -0
- package/assets/ios/iphone12promax.iphone13promax.iphone14plus-bottom.png +0 -0
- package/assets/ios/iphone13.iphone13pro.iphone14-top.png +0 -0
- package/assets/ios/iphone13mini-top.png +0 -0
- package/assets/ios/iphone13promax.iphone14plus-top.png +0 -0
- package/assets/ios/iphone14pro-bottom.png +0 -0
- package/assets/ios/iphone14pro-top.png +0 -0
- package/assets/ios/iphone14promax-bottom.png +0 -0
- package/assets/ios/iphone14promax-top.png +0 -0
- package/assets/ios/iphone15-bottom.png +0 -0
- package/assets/ios/iphone15-top.png +0 -0
- package/assets/ios/iphonex.iphonexs.iphone11pro-bottom.png +0 -0
- package/assets/ios/iphonex.iphonexs.iphone11pro-top.png +0 -0
- package/assets/ios/iphonexr.iphone11-bottom.png +0 -0
- package/assets/ios/iphonexr.iphone11-top.png +0 -0
- package/assets/ios/iphonexsmax-bottom.png +0 -0
- package/assets/ios/iphonexsmax-top.png +0 -0
- package/dist/base.d.ts +18 -0
- package/dist/base.d.ts.map +1 -0
- package/dist/base.interfaces.d.ts +200 -0
- package/dist/base.interfaces.d.ts.map +1 -0
- package/dist/base.interfaces.js +1 -0
- package/dist/base.js +58 -0
- package/dist/base.test.d.ts +2 -0
- package/dist/base.test.d.ts.map +1 -0
- package/dist/base.test.js +45 -0
- package/dist/clientSideScripts/checkMetaTag.d.ts +2 -0
- package/dist/clientSideScripts/checkMetaTag.d.ts.map +1 -0
- package/dist/clientSideScripts/checkMetaTag.js +9 -0
- package/dist/clientSideScripts/checkMetaTag.test.d.ts +2 -0
- package/dist/clientSideScripts/checkMetaTag.test.d.ts.map +1 -0
- package/dist/clientSideScripts/checkMetaTag.test.js +25 -0
- package/dist/clientSideScripts/customCss.interfaces.d.ts +8 -0
- package/dist/clientSideScripts/customCss.interfaces.d.ts.map +1 -0
- package/dist/clientSideScripts/customCss.interfaces.js +1 -0
- package/dist/clientSideScripts/drawTabbableOnCanvas.d.ts +8 -0
- package/dist/clientSideScripts/drawTabbableOnCanvas.d.ts.map +1 -0
- package/dist/clientSideScripts/drawTabbableOnCanvas.interfaces.d.ts +4 -0
- package/dist/clientSideScripts/drawTabbableOnCanvas.interfaces.d.ts.map +1 -0
- package/dist/clientSideScripts/drawTabbableOnCanvas.interfaces.js +1 -0
- package/dist/clientSideScripts/drawTabbableOnCanvas.js +275 -0
- package/dist/clientSideScripts/drawTabbableOnCanvas.test.d.ts +2 -0
- package/dist/clientSideScripts/drawTabbableOnCanvas.test.d.ts.map +1 -0
- package/dist/clientSideScripts/drawTabbableOnCanvas.test.js +251 -0
- package/dist/clientSideScripts/elementPosition.interfaces.d.ts +3 -0
- package/dist/clientSideScripts/elementPosition.interfaces.d.ts.map +1 -0
- package/dist/clientSideScripts/elementPosition.interfaces.js +1 -0
- package/dist/clientSideScripts/getBoundingClientRect.d.ts +6 -0
- package/dist/clientSideScripts/getBoundingClientRect.d.ts.map +1 -0
- package/dist/clientSideScripts/getBoundingClientRect.js +12 -0
- package/dist/clientSideScripts/getBoundingClientRect.test.d.ts +2 -0
- package/dist/clientSideScripts/getBoundingClientRect.test.d.ts.map +1 -0
- package/dist/clientSideScripts/getBoundingClientRect.test.js +28 -0
- package/dist/clientSideScripts/getDocumentScrollHeight.d.ts +5 -0
- package/dist/clientSideScripts/getDocumentScrollHeight.d.ts.map +1 -0
- package/dist/clientSideScripts/getDocumentScrollHeight.js +48 -0
- package/dist/clientSideScripts/getDocumentScrollHeight.test.d.ts +2 -0
- package/dist/clientSideScripts/getDocumentScrollHeight.test.d.ts.map +1 -0
- package/dist/clientSideScripts/getDocumentScrollHeight.test.js +30 -0
- package/dist/clientSideScripts/getElementPositionTopDom.d.ts +6 -0
- package/dist/clientSideScripts/getElementPositionTopDom.d.ts.map +1 -0
- package/dist/clientSideScripts/getElementPositionTopDom.js +11 -0
- package/dist/clientSideScripts/getElementPositionTopDom.test.d.ts +2 -0
- package/dist/clientSideScripts/getElementPositionTopDom.test.d.ts.map +1 -0
- package/dist/clientSideScripts/getElementPositionTopDom.test.js +11 -0
- package/dist/clientSideScripts/getElementPositionTopScreenNativeMobile.d.ts +14 -0
- package/dist/clientSideScripts/getElementPositionTopScreenNativeMobile.d.ts.map +1 -0
- package/dist/clientSideScripts/getElementPositionTopScreenNativeMobile.js +19 -0
- package/dist/clientSideScripts/getElementPositionTopScreenNativeMobile.test.d.ts +2 -0
- package/dist/clientSideScripts/getElementPositionTopScreenNativeMobile.test.d.ts.map +1 -0
- package/dist/clientSideScripts/getElementPositionTopScreenNativeMobile.test.js +52 -0
- package/dist/clientSideScripts/getMobileWebviewClickAndDimensions.d.ts +6 -0
- package/dist/clientSideScripts/getMobileWebviewClickAndDimensions.d.ts.map +1 -0
- package/dist/clientSideScripts/getMobileWebviewClickAndDimensions.js +17 -0
- package/dist/clientSideScripts/getMobileWebviewClickAndDimensions.test.d.ts +2 -0
- package/dist/clientSideScripts/getMobileWebviewClickAndDimensions.test.d.ts.map +1 -0
- package/dist/clientSideScripts/getMobileWebviewClickAndDimensions.test.js +47 -0
- package/dist/clientSideScripts/getScreenDimensions.d.ts +6 -0
- package/dist/clientSideScripts/getScreenDimensions.d.ts.map +1 -0
- package/dist/clientSideScripts/getScreenDimensions.js +104 -0
- package/dist/clientSideScripts/getScreenDimensions.test.d.ts +2 -0
- package/dist/clientSideScripts/getScreenDimensions.test.d.ts.map +1 -0
- package/dist/clientSideScripts/getScreenDimensions.test.js +161 -0
- package/dist/clientSideScripts/hideRemoveElements.d.ts +8 -0
- package/dist/clientSideScripts/hideRemoveElements.d.ts.map +1 -0
- package/dist/clientSideScripts/hideRemoveElements.js +60 -0
- package/dist/clientSideScripts/hideRemoveElements.test.d.ts +2 -0
- package/dist/clientSideScripts/hideRemoveElements.test.d.ts.map +1 -0
- package/dist/clientSideScripts/hideRemoveElements.test.js +199 -0
- package/dist/clientSideScripts/hideScrollbars.d.ts +9 -0
- package/dist/clientSideScripts/hideScrollbars.d.ts.map +1 -0
- package/dist/clientSideScripts/hideScrollbars.js +15 -0
- package/dist/clientSideScripts/hideScrollbars.test.d.ts +2 -0
- package/dist/clientSideScripts/hideScrollbars.test.d.ts.map +1 -0
- package/dist/clientSideScripts/hideScrollbars.test.js +12 -0
- package/dist/clientSideScripts/injectWebviewOverlay.d.ts +5 -0
- package/dist/clientSideScripts/injectWebviewOverlay.d.ts.map +1 -0
- package/dist/clientSideScripts/injectWebviewOverlay.js +35 -0
- package/dist/clientSideScripts/injectWebviewOverlay.test.d.ts +2 -0
- package/dist/clientSideScripts/injectWebviewOverlay.test.d.ts.map +1 -0
- package/dist/clientSideScripts/injectWebviewOverlay.test.js +74 -0
- package/dist/clientSideScripts/removeElementFromDom.d.ts +5 -0
- package/dist/clientSideScripts/removeElementFromDom.d.ts.map +1 -0
- package/dist/clientSideScripts/removeElementFromDom.js +9 -0
- package/dist/clientSideScripts/removeElementFromDom.test.d.ts +2 -0
- package/dist/clientSideScripts/removeElementFromDom.test.d.ts.map +1 -0
- package/dist/clientSideScripts/removeElementFromDom.test.js +43 -0
- package/dist/clientSideScripts/screenDimensions.interfaces.d.ts +96 -0
- package/dist/clientSideScripts/screenDimensions.interfaces.d.ts.map +1 -0
- package/dist/clientSideScripts/screenDimensions.interfaces.js +1 -0
- package/dist/clientSideScripts/scrollElementIntoView.d.ts +5 -0
- package/dist/clientSideScripts/scrollElementIntoView.d.ts.map +1 -0
- package/dist/clientSideScripts/scrollElementIntoView.js +31 -0
- package/dist/clientSideScripts/scrollElementIntoView.test.d.ts +2 -0
- package/dist/clientSideScripts/scrollElementIntoView.test.d.ts.map +1 -0
- package/dist/clientSideScripts/scrollElementIntoView.test.js +79 -0
- package/dist/clientSideScripts/scrollToPosition.d.ts +5 -0
- package/dist/clientSideScripts/scrollToPosition.d.ts.map +1 -0
- package/dist/clientSideScripts/scrollToPosition.js +25 -0
- package/dist/clientSideScripts/scrollToPosition.test.d.ts +2 -0
- package/dist/clientSideScripts/scrollToPosition.test.d.ts.map +1 -0
- package/dist/clientSideScripts/scrollToPosition.test.js +72 -0
- package/dist/clientSideScripts/setCustomCss.d.ts +6 -0
- package/dist/clientSideScripts/setCustomCss.d.ts.map +1 -0
- package/dist/clientSideScripts/setCustomCss.js +36 -0
- package/dist/clientSideScripts/setCustomCss.test.d.ts +2 -0
- package/dist/clientSideScripts/setCustomCss.test.d.ts.map +1 -0
- package/dist/clientSideScripts/setCustomCss.test.js +68 -0
- package/dist/clientSideScripts/statusAddressToolBarOffsets.interfaces.d.ts +11 -0
- package/dist/clientSideScripts/statusAddressToolBarOffsets.interfaces.d.ts.map +1 -0
- package/dist/clientSideScripts/statusAddressToolBarOffsets.interfaces.js +1 -0
- package/dist/clientSideScripts/toggleTextTransparency.d.ts +5 -0
- package/dist/clientSideScripts/toggleTextTransparency.d.ts.map +1 -0
- package/dist/clientSideScripts/toggleTextTransparency.js +16 -0
- package/dist/clientSideScripts/toggleTextTransparency.test.d.ts +2 -0
- package/dist/clientSideScripts/toggleTextTransparency.test.d.ts.map +1 -0
- package/dist/clientSideScripts/toggleTextTransparency.test.js +35 -0
- package/dist/clientSideScripts/waitForFonts.d.ts +8 -0
- package/dist/clientSideScripts/waitForFonts.d.ts.map +1 -0
- package/dist/clientSideScripts/waitForFonts.js +20 -0
- package/dist/clientSideScripts/waitForFonts.test.d.ts +2 -0
- package/dist/clientSideScripts/waitForFonts.test.d.ts.map +1 -0
- package/dist/clientSideScripts/waitForFonts.test.js +37 -0
- package/dist/commands/check.interfaces.d.ts +35 -0
- package/dist/commands/check.interfaces.d.ts.map +1 -0
- package/dist/commands/check.interfaces.js +1 -0
- package/dist/commands/checkAppElement.d.ts +7 -0
- package/dist/commands/checkAppElement.d.ts.map +1 -0
- package/dist/commands/checkAppElement.js +44 -0
- package/dist/commands/checkAppElement.test.d.ts +2 -0
- package/dist/commands/checkAppElement.test.d.ts.map +1 -0
- package/dist/commands/checkAppElement.test.js +241 -0
- package/dist/commands/checkAppScreen.d.ts +7 -0
- package/dist/commands/checkAppScreen.d.ts.map +1 -0
- package/dist/commands/checkAppScreen.js +73 -0
- package/dist/commands/checkAppScreen.test.d.ts +2 -0
- package/dist/commands/checkAppScreen.test.d.ts.map +1 -0
- package/dist/commands/checkAppScreen.test.js +295 -0
- package/dist/commands/checkElement.d.ts +7 -0
- package/dist/commands/checkElement.d.ts.map +1 -0
- package/dist/commands/checkElement.js +10 -0
- package/dist/commands/checkElement.test.d.ts +2 -0
- package/dist/commands/checkElement.test.d.ts.map +1 -0
- package/dist/commands/checkElement.test.js +66 -0
- package/dist/commands/checkFullPageScreen.d.ts +7 -0
- package/dist/commands/checkFullPageScreen.d.ts.map +1 -0
- package/dist/commands/checkFullPageScreen.js +56 -0
- package/dist/commands/checkFullPageScreen.test.d.ts +2 -0
- package/dist/commands/checkFullPageScreen.test.d.ts.map +1 -0
- package/dist/commands/checkFullPageScreen.test.js +259 -0
- package/dist/commands/checkScreen.d.ts +7 -0
- package/dist/commands/checkScreen.d.ts.map +1 -0
- package/dist/commands/checkScreen.js +10 -0
- package/dist/commands/checkScreen.test.d.ts +2 -0
- package/dist/commands/checkScreen.test.d.ts.map +1 -0
- package/dist/commands/checkScreen.test.js +62 -0
- package/dist/commands/checkTabbablePage.d.ts +7 -0
- package/dist/commands/checkTabbablePage.d.ts.map +1 -0
- package/dist/commands/checkTabbablePage.js +28 -0
- package/dist/commands/checkTabbablePage.test.d.ts +2 -0
- package/dist/commands/checkTabbablePage.test.d.ts.map +1 -0
- package/dist/commands/checkTabbablePage.test.js +200 -0
- package/dist/commands/checkWebElement.d.ts +7 -0
- package/dist/commands/checkWebElement.d.ts.map +1 -0
- package/dist/commands/checkWebElement.js +52 -0
- package/dist/commands/checkWebElement.test.d.ts +2 -0
- package/dist/commands/checkWebElement.test.d.ts.map +1 -0
- package/dist/commands/checkWebElement.test.js +278 -0
- package/dist/commands/checkWebScreen.d.ts +7 -0
- package/dist/commands/checkWebScreen.d.ts.map +1 -0
- package/dist/commands/checkWebScreen.js +50 -0
- package/dist/commands/checkWebScreen.test.d.ts +2 -0
- package/dist/commands/checkWebScreen.test.d.ts.map +1 -0
- package/dist/commands/checkWebScreen.test.js +227 -0
- package/dist/commands/element.interfaces.d.ts +27 -0
- package/dist/commands/element.interfaces.d.ts.map +1 -0
- package/dist/commands/element.interfaces.js +1 -0
- package/dist/commands/fullPage.interfaces.d.ts +38 -0
- package/dist/commands/fullPage.interfaces.d.ts.map +1 -0
- package/dist/commands/fullPage.interfaces.js +1 -0
- package/dist/commands/save.interfaces.d.ts +27 -0
- package/dist/commands/save.interfaces.d.ts.map +1 -0
- package/dist/commands/save.interfaces.js +1 -0
- package/dist/commands/saveAppElement.d.ts +7 -0
- package/dist/commands/saveAppElement.d.ts.map +1 -0
- package/dist/commands/saveAppElement.js +30 -0
- package/dist/commands/saveAppElement.test.d.ts +2 -0
- package/dist/commands/saveAppElement.test.d.ts.map +1 -0
- package/dist/commands/saveAppElement.test.js +199 -0
- package/dist/commands/saveAppScreen.d.ts +7 -0
- package/dist/commands/saveAppScreen.d.ts.map +1 -0
- package/dist/commands/saveAppScreen.js +43 -0
- package/dist/commands/saveAppScreen.test.d.ts +2 -0
- package/dist/commands/saveAppScreen.test.d.ts.map +1 -0
- package/dist/commands/saveAppScreen.test.js +221 -0
- package/dist/commands/saveElement.d.ts +7 -0
- package/dist/commands/saveElement.d.ts.map +1 -0
- package/dist/commands/saveElement.js +10 -0
- package/dist/commands/saveElement.test.d.ts +2 -0
- package/dist/commands/saveElement.test.d.ts.map +1 -0
- package/dist/commands/saveElement.test.js +62 -0
- package/dist/commands/saveFullPageScreen.d.ts +7 -0
- package/dist/commands/saveFullPageScreen.d.ts.map +1 -0
- package/dist/commands/saveFullPageScreen.js +60 -0
- package/dist/commands/saveFullPageScreen.test.d.ts +2 -0
- package/dist/commands/saveFullPageScreen.test.d.ts.map +1 -0
- package/dist/commands/saveFullPageScreen.test.js +293 -0
- package/dist/commands/saveScreen.d.ts +7 -0
- package/dist/commands/saveScreen.d.ts.map +1 -0
- package/dist/commands/saveScreen.js +10 -0
- package/dist/commands/saveScreen.test.d.ts +2 -0
- package/dist/commands/saveScreen.test.d.ts.map +1 -0
- package/dist/commands/saveScreen.test.js +47 -0
- package/dist/commands/saveTabbablePage.d.ts +7 -0
- package/dist/commands/saveTabbablePage.d.ts.map +1 -0
- package/dist/commands/saveTabbablePage.js +20 -0
- package/dist/commands/saveTabbablePage.test.d.ts +2 -0
- package/dist/commands/saveTabbablePage.test.d.ts.map +1 -0
- package/dist/commands/saveTabbablePage.test.js +74 -0
- package/dist/commands/saveWebElement.d.ts +7 -0
- package/dist/commands/saveWebElement.d.ts.map +1 -0
- package/dist/commands/saveWebElement.js +53 -0
- package/dist/commands/saveWebElement.test.d.ts +2 -0
- package/dist/commands/saveWebElement.test.d.ts.map +1 -0
- package/dist/commands/saveWebElement.test.js +253 -0
- package/dist/commands/saveWebScreen.d.ts +7 -0
- package/dist/commands/saveWebScreen.d.ts.map +1 -0
- package/dist/commands/saveWebScreen.js +48 -0
- package/dist/commands/saveWebScreen.test.d.ts +2 -0
- package/dist/commands/saveWebScreen.test.d.ts.map +1 -0
- package/dist/commands/saveWebScreen.test.js +222 -0
- package/dist/commands/screen.interfaces.d.ts +16 -0
- package/dist/commands/screen.interfaces.d.ts.map +1 -0
- package/dist/commands/screen.interfaces.js +1 -0
- package/dist/commands/tabbable.interfaces.d.ts +29 -0
- package/dist/commands/tabbable.interfaces.d.ts.map +1 -0
- package/dist/commands/tabbable.interfaces.js +1 -0
- package/dist/helpers/afterScreenshot.d.ts +7 -0
- package/dist/helpers/afterScreenshot.d.ts.map +1 -0
- package/dist/helpers/afterScreenshot.interfaces.d.ts +46 -0
- package/dist/helpers/afterScreenshot.interfaces.d.ts.map +1 -0
- package/dist/helpers/afterScreenshot.interfaces.js +1 -0
- package/dist/helpers/afterScreenshot.js +55 -0
- package/dist/helpers/afterScreenshot.test.d.ts +2 -0
- package/dist/helpers/afterScreenshot.test.d.ts.map +1 -0
- package/dist/helpers/afterScreenshot.test.js +241 -0
- package/dist/helpers/beforeScreenshot.d.ts +6 -0
- package/dist/helpers/beforeScreenshot.d.ts.map +1 -0
- package/dist/helpers/beforeScreenshot.interfaces.d.ts +15 -0
- package/dist/helpers/beforeScreenshot.interfaces.d.ts.map +1 -0
- package/dist/helpers/beforeScreenshot.interfaces.js +1 -0
- package/dist/helpers/beforeScreenshot.js +79 -0
- package/dist/helpers/beforeScreenshot.test.d.ts +2 -0
- package/dist/helpers/beforeScreenshot.test.d.ts.map +1 -0
- package/dist/helpers/beforeScreenshot.test.js +261 -0
- package/dist/helpers/compare.interfaces.d.ts +16 -0
- package/dist/helpers/compare.interfaces.d.ts.map +1 -0
- package/dist/helpers/compare.interfaces.js +1 -0
- package/dist/helpers/constants.d.ts +108 -0
- package/dist/helpers/constants.d.ts.map +1 -0
- package/dist/helpers/constants.interfaces.d.ts +30 -0
- package/dist/helpers/constants.interfaces.d.ts.map +1 -0
- package/dist/helpers/constants.interfaces.js +11 -0
- package/dist/helpers/constants.js +436 -0
- package/dist/helpers/options.d.ts +64 -0
- package/dist/helpers/options.d.ts.map +1 -0
- package/dist/helpers/options.interfaces.d.ts +363 -0
- package/dist/helpers/options.interfaces.d.ts.map +1 -0
- package/dist/helpers/options.interfaces.js +1 -0
- package/dist/helpers/options.js +184 -0
- package/dist/helpers/options.test.d.ts +2 -0
- package/dist/helpers/options.test.d.ts.map +1 -0
- package/dist/helpers/options.test.js +428 -0
- package/dist/helpers/utils.d.ts +134 -0
- package/dist/helpers/utils.d.ts.map +1 -0
- package/dist/helpers/utils.interfaces.d.ts +254 -0
- package/dist/helpers/utils.interfaces.d.ts.map +1 -0
- package/dist/helpers/utils.interfaces.js +1 -0
- package/dist/helpers/utils.js +566 -0
- package/dist/helpers/utils.test.d.ts +2 -0
- package/dist/helpers/utils.test.d.ts.map +1 -0
- package/dist/helpers/utils.test.js +900 -0
- package/dist/index.d.ts +26 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +18 -0
- package/dist/methods/compareReport.interfaces.d.ts +109 -0
- package/dist/methods/compareReport.interfaces.d.ts.map +1 -0
- package/dist/methods/compareReport.interfaces.js +1 -0
- package/dist/methods/createCompareReport.d.ts +7 -0
- package/dist/methods/createCompareReport.d.ts.map +1 -0
- package/dist/methods/createCompareReport.js +61 -0
- package/dist/methods/createCompareReport.test.d.ts +2 -0
- package/dist/methods/createCompareReport.test.d.ts.map +1 -0
- package/dist/methods/createCompareReport.test.js +236 -0
- package/dist/methods/elementPosition.d.ts +18 -0
- package/dist/methods/elementPosition.d.ts.map +1 -0
- package/dist/methods/elementPosition.interfaces.d.ts +14 -0
- package/dist/methods/elementPosition.interfaces.d.ts.map +1 -0
- package/dist/methods/elementPosition.interfaces.js +1 -0
- package/dist/methods/elementPosition.js +34 -0
- package/dist/methods/images.d.ts +69 -0
- package/dist/methods/images.d.ts.map +1 -0
- package/dist/methods/images.executeImageCompare.test.d.ts +2 -0
- package/dist/methods/images.executeImageCompare.test.d.ts.map +1 -0
- package/dist/methods/images.executeImageCompare.test.js +770 -0
- package/dist/methods/images.interfaces.d.ts +214 -0
- package/dist/methods/images.interfaces.d.ts.map +1 -0
- package/dist/methods/images.interfaces.js +1 -0
- package/dist/methods/images.js +428 -0
- package/dist/methods/images.test.d.ts +2 -0
- package/dist/methods/images.test.d.ts.map +1 -0
- package/dist/methods/images.test.js +1465 -0
- package/dist/methods/instanceData.d.ts +6 -0
- package/dist/methods/instanceData.d.ts.map +1 -0
- package/dist/methods/instanceData.interfaces.d.ts +57 -0
- package/dist/methods/instanceData.interfaces.d.ts.map +1 -0
- package/dist/methods/instanceData.interfaces.js +1 -0
- package/dist/methods/instanceData.js +42 -0
- package/dist/methods/instanceData.test.d.ts +2 -0
- package/dist/methods/instanceData.test.d.ts.map +1 -0
- package/dist/methods/instanceData.test.js +224 -0
- package/dist/methods/processDiffPixels.d.ts +59 -0
- package/dist/methods/processDiffPixels.d.ts.map +1 -0
- package/dist/methods/processDiffPixels.js +242 -0
- package/dist/methods/processDiffPixels.test.d.ts +2 -0
- package/dist/methods/processDiffPixels.test.d.ts.map +1 -0
- package/dist/methods/processDiffPixels.test.js +122 -0
- package/dist/methods/rectangles.d.ts +51 -0
- package/dist/methods/rectangles.d.ts.map +1 -0
- package/dist/methods/rectangles.interfaces.d.ts +146 -0
- package/dist/methods/rectangles.interfaces.d.ts.map +1 -0
- package/dist/methods/rectangles.interfaces.js +1 -0
- package/dist/methods/rectangles.js +266 -0
- package/dist/methods/rectangles.test.d.ts +2 -0
- package/dist/methods/rectangles.test.d.ts.map +1 -0
- package/dist/methods/rectangles.test.js +853 -0
- package/dist/methods/screenshots.d.ts +37 -0
- package/dist/methods/screenshots.d.ts.map +1 -0
- package/dist/methods/screenshots.interfaces.d.ts +203 -0
- package/dist/methods/screenshots.interfaces.d.ts.map +1 -0
- package/dist/methods/screenshots.interfaces.js +1 -0
- package/dist/methods/screenshots.js +394 -0
- package/dist/methods/screenshots.test.d.ts +2 -0
- package/dist/methods/screenshots.test.d.ts.map +1 -0
- package/dist/methods/screenshots.test.js +656 -0
- package/dist/methods/takeElementScreenshots.d.ts +3 -0
- package/dist/methods/takeElementScreenshots.d.ts.map +1 -0
- package/dist/methods/takeElementScreenshots.js +104 -0
- package/dist/methods/takeElementScreenshots.test.d.ts +2 -0
- package/dist/methods/takeElementScreenshots.test.d.ts.map +1 -0
- package/dist/methods/takeElementScreenshots.test.js +314 -0
- package/dist/methods/takeFullPageScreenshots.d.ts +3 -0
- package/dist/methods/takeFullPageScreenshots.d.ts.map +1 -0
- package/dist/methods/takeFullPageScreenshots.js +56 -0
- package/dist/methods/takeFullPageScreenshots.test.d.ts +2 -0
- package/dist/methods/takeFullPageScreenshots.test.d.ts.map +1 -0
- package/dist/methods/takeFullPageScreenshots.test.js +72 -0
- package/dist/methods/takeWebScreenshots.d.ts +3 -0
- package/dist/methods/takeWebScreenshots.d.ts.map +1 -0
- package/dist/methods/takeWebScreenshots.js +41 -0
- package/dist/methods/takeWebScreenshots.test.d.ts +2 -0
- package/dist/methods/takeWebScreenshots.test.d.ts.map +1 -0
- package/dist/methods/takeWebScreenshots.test.js +149 -0
- package/dist/mocks/image.d.ts +4 -0
- package/dist/mocks/image.d.ts.map +1 -0
- package/dist/mocks/image.js +3 -0
- package/dist/mocks/mocks.d.ts +745 -0
- package/dist/mocks/mocks.d.ts.map +1 -0
- package/dist/mocks/mocks.js +392 -0
- package/dist/resemble/compare.interfaces.d.ts +136 -0
- package/dist/resemble/compare.interfaces.d.ts.map +1 -0
- package/dist/resemble/compare.interfaces.js +1 -0
- package/dist/resemble/compareImages.d.ts +3 -0
- package/dist/resemble/compareImages.d.ts.map +1 -0
- package/dist/resemble/compareImages.js +21 -0
- package/dist/resemble/resemble.jimp.cjs +981 -0
- package/dist/resemble/resemble.jimp.d.cts +46 -0
- package/dist/resemble/resemble.jimp.d.cts.map +1 -0
- package/package.json +47 -0
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { join } from 'node:path';
|
|
2
|
+
import logger from '@wdio/logger';
|
|
3
|
+
import hideScrollBars from '../clientSideScripts/hideScrollbars.js';
|
|
4
|
+
import removeElementFromDom from '../clientSideScripts/removeElementFromDom.js';
|
|
5
|
+
import { CUSTOM_CSS_ID } from './constants.js';
|
|
6
|
+
import { formatFileName, getAndCreatePath } from './utils.js';
|
|
7
|
+
import { saveBase64Image } from '../methods/images.js';
|
|
8
|
+
import hideRemoveElements from '../clientSideScripts/hideRemoveElements.js';
|
|
9
|
+
import toggleTextTransparency from '../clientSideScripts/toggleTextTransparency.js';
|
|
10
|
+
const log = logger('@wdio/visual-service:@wdio/image-comparison-core:afterScreenshot');
|
|
11
|
+
/**
|
|
12
|
+
* Methods that need to be executed after a screenshot has been taken
|
|
13
|
+
* to set all back to the original state
|
|
14
|
+
*/
|
|
15
|
+
export default async function afterScreenshot(browserInstance, options) {
|
|
16
|
+
const { actualFolder, base64Image, disableBlinkingCursor, disableCSSAnimation, enableLayoutTesting, fileName: fileNameOptions, filePath, hideElements, hideScrollBars: noScrollBars, isLandscape, isNativeContext, removeElements, } = options;
|
|
17
|
+
const path = getAndCreatePath(actualFolder, filePath);
|
|
18
|
+
const fileName = formatFileName(fileNameOptions);
|
|
19
|
+
await saveBase64Image(base64Image, join(path, fileName));
|
|
20
|
+
const result = {
|
|
21
|
+
devicePixelRatio: fileNameOptions.devicePixelRatio,
|
|
22
|
+
fileName,
|
|
23
|
+
isLandscape,
|
|
24
|
+
path,
|
|
25
|
+
};
|
|
26
|
+
if (isNativeContext) {
|
|
27
|
+
return result;
|
|
28
|
+
}
|
|
29
|
+
if (noScrollBars) {
|
|
30
|
+
await browserInstance.execute(hideScrollBars, !noScrollBars);
|
|
31
|
+
}
|
|
32
|
+
if ((hideElements && hideElements.length > 0) || (removeElements && removeElements.length > 0)) {
|
|
33
|
+
try {
|
|
34
|
+
await browserInstance.execute(hideRemoveElements, { hide: hideElements, remove: removeElements }, false);
|
|
35
|
+
}
|
|
36
|
+
catch (e) {
|
|
37
|
+
log.warn('\x1b[33m%s\x1b[0m', `
|
|
38
|
+
#####################################################################################
|
|
39
|
+
WARNING:
|
|
40
|
+
(One of) the elements that needed to be hidden or removed could not be found on the
|
|
41
|
+
page and caused this error
|
|
42
|
+
Error: ${e}
|
|
43
|
+
We made sure the test didn't break.
|
|
44
|
+
#####################################################################################
|
|
45
|
+
`);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
if (disableCSSAnimation || disableBlinkingCursor || browserInstance.isMobile) {
|
|
49
|
+
await browserInstance.execute(removeElementFromDom, CUSTOM_CSS_ID);
|
|
50
|
+
}
|
|
51
|
+
if (enableLayoutTesting) {
|
|
52
|
+
await browserInstance.execute(toggleTextTransparency, !enableLayoutTesting);
|
|
53
|
+
}
|
|
54
|
+
return result;
|
|
55
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"afterScreenshot.test.d.ts","sourceRoot":"","sources":["../../src/helpers/afterScreenshot.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
import { join } from 'node:path';
|
|
2
|
+
import logger from '@wdio/logger';
|
|
3
|
+
import { describe, it, expect, afterEach, beforeEach, vi } from 'vitest';
|
|
4
|
+
import afterScreenshot from './afterScreenshot.js';
|
|
5
|
+
import hideScrollBars from '../clientSideScripts/hideScrollbars.js';
|
|
6
|
+
import hideRemoveElements from '../clientSideScripts/hideRemoveElements.js';
|
|
7
|
+
import removeElementFromDom from '../clientSideScripts/removeElementFromDom.js';
|
|
8
|
+
import toggleTextTransparency from '../clientSideScripts/toggleTextTransparency.js';
|
|
9
|
+
import { CUSTOM_CSS_ID } from './constants.js';
|
|
10
|
+
const log = logger('test');
|
|
11
|
+
vi.mock('@wdio/logger', () => import(join(process.cwd(), '__mocks__', '@wdio/logger')));
|
|
12
|
+
vi.mock('../methods/images.js', () => ({
|
|
13
|
+
saveBase64Image: vi.fn()
|
|
14
|
+
}));
|
|
15
|
+
vi.mock('./utils.js', () => ({
|
|
16
|
+
getAndCreatePath: vi.fn(),
|
|
17
|
+
formatFileName: vi.fn()
|
|
18
|
+
}));
|
|
19
|
+
import { saveBase64Image } from '../methods/images.js';
|
|
20
|
+
import { getAndCreatePath, formatFileName } from './utils.js';
|
|
21
|
+
describe('afterScreenshot', () => {
|
|
22
|
+
const mockPath = '/mocked/path';
|
|
23
|
+
const mockFileName = 'mocked-file-name.png';
|
|
24
|
+
afterEach(() => {
|
|
25
|
+
vi.clearAllMocks();
|
|
26
|
+
});
|
|
27
|
+
beforeEach(() => {
|
|
28
|
+
vi.mocked(getAndCreatePath).mockReturnValue(mockPath);
|
|
29
|
+
vi.mocked(formatFileName).mockReturnValue(mockFileName);
|
|
30
|
+
});
|
|
31
|
+
const createMockBrowserInstance = (mockExecuteFn = vi.fn().mockResolvedValue(''), customProperties = {}) => {
|
|
32
|
+
return {
|
|
33
|
+
execute: mockExecuteFn,
|
|
34
|
+
...customProperties
|
|
35
|
+
};
|
|
36
|
+
};
|
|
37
|
+
const baseFilePath = {
|
|
38
|
+
browserName: 'browserName',
|
|
39
|
+
deviceName: 'deviceName',
|
|
40
|
+
isMobile: false,
|
|
41
|
+
savePerInstance: true,
|
|
42
|
+
};
|
|
43
|
+
const baseFileName = {
|
|
44
|
+
browserName: 'browserName',
|
|
45
|
+
browserVersion: 'browserVersion',
|
|
46
|
+
deviceName: 'deviceName',
|
|
47
|
+
devicePixelRatio: 2,
|
|
48
|
+
formatImageName: '{tag}-{browserName}-{width}x{height}-dpr-{dpr}',
|
|
49
|
+
isMobile: false,
|
|
50
|
+
isTestInBrowser: true,
|
|
51
|
+
logName: 'logName',
|
|
52
|
+
name: 'name',
|
|
53
|
+
outerHeight: 850,
|
|
54
|
+
outerWidth: 1400,
|
|
55
|
+
platformName: 'platformName',
|
|
56
|
+
platformVersion: 'platformVersion',
|
|
57
|
+
screenHeight: 900,
|
|
58
|
+
screenWidth: 1440,
|
|
59
|
+
tag: 'tag',
|
|
60
|
+
};
|
|
61
|
+
const createBaseOptions = (overrides = {}) => ({
|
|
62
|
+
actualFolder: mockPath,
|
|
63
|
+
base64Image: 'string',
|
|
64
|
+
filePath: baseFilePath,
|
|
65
|
+
fileName: baseFileName,
|
|
66
|
+
hideScrollBars: false,
|
|
67
|
+
isLandscape: false,
|
|
68
|
+
isNativeContext: false,
|
|
69
|
+
platformName: '',
|
|
70
|
+
...overrides,
|
|
71
|
+
});
|
|
72
|
+
it('should be able to return the ScreenshotOutput with default options', async () => {
|
|
73
|
+
const mockBrowserInstance = createMockBrowserInstance();
|
|
74
|
+
const options = createBaseOptions({
|
|
75
|
+
disableBlinkingCursor: false,
|
|
76
|
+
disableCSSAnimation: false,
|
|
77
|
+
hideScrollBars: true,
|
|
78
|
+
hideElements: ['<div></div>'],
|
|
79
|
+
removeElements: ['<div></div>'],
|
|
80
|
+
});
|
|
81
|
+
const result = await afterScreenshot(mockBrowserInstance, options);
|
|
82
|
+
expect(vi.mocked(getAndCreatePath)).toHaveBeenCalledWith(mockPath, options.filePath);
|
|
83
|
+
expect(vi.mocked(formatFileName)).toHaveBeenCalledWith(options.fileName);
|
|
84
|
+
expect(vi.mocked(saveBase64Image)).toHaveBeenCalledWith(options.base64Image, join(mockPath, mockFileName));
|
|
85
|
+
expect(result).toMatchSnapshot();
|
|
86
|
+
});
|
|
87
|
+
it('should handle native context and skip browser operations', async () => {
|
|
88
|
+
const mockBrowserInstance = createMockBrowserInstance();
|
|
89
|
+
const options = createBaseOptions({
|
|
90
|
+
disableBlinkingCursor: true,
|
|
91
|
+
disableCSSAnimation: true,
|
|
92
|
+
enableLayoutTesting: true,
|
|
93
|
+
fileName: {
|
|
94
|
+
...baseFileName,
|
|
95
|
+
devicePixelRatio: 1.5,
|
|
96
|
+
outerHeight: 600,
|
|
97
|
+
outerWidth: 800,
|
|
98
|
+
screenHeight: 700,
|
|
99
|
+
screenWidth: 900,
|
|
100
|
+
},
|
|
101
|
+
hideScrollBars: true,
|
|
102
|
+
isLandscape: true,
|
|
103
|
+
isNativeContext: true,
|
|
104
|
+
hideElements: ['<div></div>'],
|
|
105
|
+
platformName: 'iOS',
|
|
106
|
+
removeElements: ['<div></div>'],
|
|
107
|
+
});
|
|
108
|
+
const result = await afterScreenshot(mockBrowserInstance, options);
|
|
109
|
+
expect(vi.mocked(getAndCreatePath)).toHaveBeenCalledWith(mockPath, options.filePath);
|
|
110
|
+
expect(vi.mocked(formatFileName)).toHaveBeenCalledWith(options.fileName);
|
|
111
|
+
expect(vi.mocked(saveBase64Image)).toHaveBeenCalledWith(options.base64Image, join(mockPath, mockFileName));
|
|
112
|
+
expect(mockBrowserInstance.execute).not.toHaveBeenCalled();
|
|
113
|
+
expect(result).toMatchSnapshot();
|
|
114
|
+
});
|
|
115
|
+
it('should handle layout testing with enableLayoutTesting', async () => {
|
|
116
|
+
const mockExecute = vi.fn().mockResolvedValue('');
|
|
117
|
+
const mockBrowserInstance = createMockBrowserInstance(mockExecute);
|
|
118
|
+
const options = createBaseOptions({
|
|
119
|
+
enableLayoutTesting: true,
|
|
120
|
+
});
|
|
121
|
+
const result = await afterScreenshot(mockBrowserInstance, options);
|
|
122
|
+
expect(vi.mocked(getAndCreatePath)).toHaveBeenCalledWith(mockPath, options.filePath);
|
|
123
|
+
expect(vi.mocked(formatFileName)).toHaveBeenCalledWith(options.fileName);
|
|
124
|
+
expect(vi.mocked(saveBase64Image)).toHaveBeenCalledWith(options.base64Image, join(mockPath, mockFileName));
|
|
125
|
+
expect(mockExecute).toHaveBeenCalledWith(toggleTextTransparency, false);
|
|
126
|
+
expect(result).toMatchSnapshot();
|
|
127
|
+
});
|
|
128
|
+
it('should handle mobile platform and remove custom CSS', async () => {
|
|
129
|
+
const mockExecute = vi.fn().mockResolvedValue('');
|
|
130
|
+
const mockBrowserInstance = createMockBrowserInstance(mockExecute, { isMobile: true });
|
|
131
|
+
const options = createBaseOptions({
|
|
132
|
+
disableBlinkingCursor: false,
|
|
133
|
+
disableCSSAnimation: false,
|
|
134
|
+
filePath: {
|
|
135
|
+
...baseFilePath,
|
|
136
|
+
isMobile: true,
|
|
137
|
+
},
|
|
138
|
+
fileName: {
|
|
139
|
+
...baseFileName,
|
|
140
|
+
isMobile: true,
|
|
141
|
+
platformName: 'Android',
|
|
142
|
+
},
|
|
143
|
+
platformName: 'Android',
|
|
144
|
+
});
|
|
145
|
+
const result = await afterScreenshot(mockBrowserInstance, options);
|
|
146
|
+
expect(vi.mocked(getAndCreatePath)).toHaveBeenCalledWith(mockPath, options.filePath);
|
|
147
|
+
expect(vi.mocked(formatFileName)).toHaveBeenCalledWith(options.fileName);
|
|
148
|
+
expect(vi.mocked(saveBase64Image)).toHaveBeenCalledWith(options.base64Image, join(mockPath, mockFileName));
|
|
149
|
+
expect(mockExecute).toHaveBeenCalledWith(removeElementFromDom, CUSTOM_CSS_ID);
|
|
150
|
+
expect(result).toMatchSnapshot();
|
|
151
|
+
});
|
|
152
|
+
it('should handle hide/remove elements with error handling', async () => {
|
|
153
|
+
const mockExecute = vi.fn().mockRejectedValueOnce(new Error('Element not found'));
|
|
154
|
+
const mockBrowserInstance = createMockBrowserInstance(mockExecute);
|
|
155
|
+
const hideElements = ['<div></div>'];
|
|
156
|
+
const removeElements = ['<div></div>'];
|
|
157
|
+
const options = createBaseOptions({
|
|
158
|
+
hideElements,
|
|
159
|
+
removeElements,
|
|
160
|
+
});
|
|
161
|
+
const result = await afterScreenshot(mockBrowserInstance, options);
|
|
162
|
+
expect(vi.mocked(getAndCreatePath)).toHaveBeenCalledWith(mockPath, options.filePath);
|
|
163
|
+
expect(vi.mocked(formatFileName)).toHaveBeenCalledWith(options.fileName);
|
|
164
|
+
expect(vi.mocked(saveBase64Image)).toHaveBeenCalledWith(options.base64Image, join(mockPath, mockFileName));
|
|
165
|
+
expect(mockExecute).toHaveBeenCalledWith(hideRemoveElements, { hide: hideElements, remove: removeElements }, false);
|
|
166
|
+
expect(log.warn).toHaveBeenCalledTimes(1);
|
|
167
|
+
expect(vi.mocked(log.warn).mock.calls[0]).toMatchSnapshot();
|
|
168
|
+
expect(result).toMatchSnapshot();
|
|
169
|
+
});
|
|
170
|
+
it('should handle hideScrollBars when hideScrollBars is true', async () => {
|
|
171
|
+
const mockExecute = vi.fn().mockResolvedValue('');
|
|
172
|
+
const mockBrowserInstance = createMockBrowserInstance(mockExecute);
|
|
173
|
+
const options = createBaseOptions({
|
|
174
|
+
hideScrollBars: true,
|
|
175
|
+
});
|
|
176
|
+
const result = await afterScreenshot(mockBrowserInstance, options);
|
|
177
|
+
expect(vi.mocked(getAndCreatePath)).toHaveBeenCalledWith(mockPath, options.filePath);
|
|
178
|
+
expect(vi.mocked(formatFileName)).toHaveBeenCalledWith(options.fileName);
|
|
179
|
+
expect(vi.mocked(saveBase64Image)).toHaveBeenCalledWith(options.base64Image, join(mockPath, mockFileName));
|
|
180
|
+
expect(mockExecute).toHaveBeenCalledWith(hideScrollBars, false);
|
|
181
|
+
expect(result).toMatchSnapshot();
|
|
182
|
+
});
|
|
183
|
+
it('should skip hide/remove elements when both are empty arrays', async () => {
|
|
184
|
+
const mockExecute = vi.fn().mockResolvedValue('');
|
|
185
|
+
const mockBrowserInstance = createMockBrowserInstance(mockExecute);
|
|
186
|
+
const options = createBaseOptions({
|
|
187
|
+
hideElements: [],
|
|
188
|
+
removeElements: [],
|
|
189
|
+
});
|
|
190
|
+
const result = await afterScreenshot(mockBrowserInstance, options);
|
|
191
|
+
expect(vi.mocked(getAndCreatePath)).toHaveBeenCalledWith(mockPath, options.filePath);
|
|
192
|
+
expect(vi.mocked(formatFileName)).toHaveBeenCalledWith(options.fileName);
|
|
193
|
+
expect(vi.mocked(saveBase64Image)).toHaveBeenCalledWith(options.base64Image, join(mockPath, mockFileName));
|
|
194
|
+
expect(mockExecute).not.toHaveBeenCalledWith(hideRemoveElements, expect.any(Object), false);
|
|
195
|
+
expect(result).toMatchSnapshot();
|
|
196
|
+
});
|
|
197
|
+
it('should skip hide/remove elements when both are falsy', async () => {
|
|
198
|
+
const mockExecute = vi.fn().mockResolvedValue('');
|
|
199
|
+
const mockBrowserInstance = createMockBrowserInstance(mockExecute);
|
|
200
|
+
const options = createBaseOptions({
|
|
201
|
+
hideElements: undefined,
|
|
202
|
+
removeElements: null,
|
|
203
|
+
});
|
|
204
|
+
const result = await afterScreenshot(mockBrowserInstance, options);
|
|
205
|
+
expect(vi.mocked(getAndCreatePath)).toHaveBeenCalledWith(mockPath, options.filePath);
|
|
206
|
+
expect(vi.mocked(formatFileName)).toHaveBeenCalledWith(options.fileName);
|
|
207
|
+
expect(vi.mocked(saveBase64Image)).toHaveBeenCalledWith(options.base64Image, join(mockPath, mockFileName));
|
|
208
|
+
expect(mockExecute).not.toHaveBeenCalledWith(hideRemoveElements, expect.any(Object), false);
|
|
209
|
+
expect(result).toMatchSnapshot();
|
|
210
|
+
});
|
|
211
|
+
it('should handle only hideElements with length > 0', async () => {
|
|
212
|
+
const mockExecute = vi.fn().mockResolvedValue('');
|
|
213
|
+
const mockBrowserInstance = createMockBrowserInstance(mockExecute);
|
|
214
|
+
const hideElements = ['<div></div>'];
|
|
215
|
+
const options = createBaseOptions({
|
|
216
|
+
hideElements,
|
|
217
|
+
removeElements: [],
|
|
218
|
+
});
|
|
219
|
+
const result = await afterScreenshot(mockBrowserInstance, options);
|
|
220
|
+
expect(vi.mocked(getAndCreatePath)).toHaveBeenCalledWith(mockPath, options.filePath);
|
|
221
|
+
expect(vi.mocked(formatFileName)).toHaveBeenCalledWith(options.fileName);
|
|
222
|
+
expect(vi.mocked(saveBase64Image)).toHaveBeenCalledWith(options.base64Image, join(mockPath, mockFileName));
|
|
223
|
+
expect(mockExecute).toHaveBeenCalledWith(hideRemoveElements, { hide: hideElements, remove: [] }, false);
|
|
224
|
+
expect(result).toMatchSnapshot();
|
|
225
|
+
});
|
|
226
|
+
it('should handle only removeElements with length > 0', async () => {
|
|
227
|
+
const mockExecute = vi.fn().mockResolvedValue('');
|
|
228
|
+
const mockBrowserInstance = createMockBrowserInstance(mockExecute);
|
|
229
|
+
const removeElements = ['<div></div>'];
|
|
230
|
+
const options = createBaseOptions({
|
|
231
|
+
hideElements: null,
|
|
232
|
+
removeElements,
|
|
233
|
+
});
|
|
234
|
+
const result = await afterScreenshot(mockBrowserInstance, options);
|
|
235
|
+
expect(vi.mocked(getAndCreatePath)).toHaveBeenCalledWith(mockPath, options.filePath);
|
|
236
|
+
expect(vi.mocked(formatFileName)).toHaveBeenCalledWith(options.fileName);
|
|
237
|
+
expect(vi.mocked(saveBase64Image)).toHaveBeenCalledWith(options.base64Image, join(mockPath, mockFileName));
|
|
238
|
+
expect(mockExecute).toHaveBeenCalledWith(hideRemoveElements, { hide: null, remove: removeElements }, false);
|
|
239
|
+
expect(result).toMatchSnapshot();
|
|
240
|
+
});
|
|
241
|
+
});
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { BeforeScreenshotOptions, BeforeScreenshotResult } from './beforeScreenshot.interfaces.js';
|
|
2
|
+
/**
|
|
3
|
+
* Methods that need to be executed before a screenshot will be taken
|
|
4
|
+
*/
|
|
5
|
+
export default function beforeScreenshot(browserInstance: WebdriverIO.Browser, options: BeforeScreenshotOptions, addShadowPadding?: boolean): Promise<BeforeScreenshotResult>;
|
|
6
|
+
//# sourceMappingURL=beforeScreenshot.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beforeScreenshot.d.ts","sourceRoot":"","sources":["../../src/helpers/beforeScreenshot.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,uBAAuB,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAA;AAOvG;;GAEG;AACH,wBAA8B,gBAAgB,CAC1C,eAAe,EAAE,WAAW,CAAC,OAAO,EACpC,OAAO,EAAE,uBAAuB,EAChC,gBAAgB,UAAQ,GACzB,OAAO,CAAC,sBAAsB,CAAC,CAmFjC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { EnrichedInstanceData, InstanceData } from '../methods/instanceData.interfaces.js';
|
|
2
|
+
export interface BeforeScreenshotOptions {
|
|
3
|
+
instanceData: InstanceData;
|
|
4
|
+
addressBarShadowPadding: number;
|
|
5
|
+
disableBlinkingCursor: boolean;
|
|
6
|
+
disableCSSAnimation: boolean;
|
|
7
|
+
enableLayoutTesting: boolean;
|
|
8
|
+
noScrollBars: boolean;
|
|
9
|
+
toolBarShadowPadding: number;
|
|
10
|
+
hideElements: HTMLElement[];
|
|
11
|
+
removeElements: HTMLElement[];
|
|
12
|
+
waitForFontsLoaded: boolean;
|
|
13
|
+
}
|
|
14
|
+
export type BeforeScreenshotResult = EnrichedInstanceData;
|
|
15
|
+
//# sourceMappingURL=beforeScreenshot.interfaces.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beforeScreenshot.interfaces.d.ts","sourceRoot":"","sources":["../../src/helpers/beforeScreenshot.interfaces.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,uCAAuC,CAAA;AAE/F,MAAM,WAAW,uBAAuB;IAEpC,YAAY,EAAE,YAAY,CAAC;IAE3B,uBAAuB,EAAE,MAAM,CAAC;IAEhC,qBAAqB,EAAE,OAAO,CAAC;IAE/B,mBAAmB,EAAE,OAAO,CAAC;IAE7B,mBAAmB,EAAE,OAAO,CAAC;IAE7B,YAAY,EAAE,OAAO,CAAC;IAEtB,oBAAoB,EAAE,MAAM,CAAC;IAE7B,YAAY,EAAE,WAAW,EAAE,CAAC;IAE5B,cAAc,EAAE,WAAW,EAAE,CAAC;IAE9B,kBAAkB,EAAE,OAAO,CAAC;CAC/B;AAED,MAAM,MAAM,sBAAsB,GAAG,oBAAoB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import logger from '@wdio/logger';
|
|
2
|
+
import hideScrollBars from '../clientSideScripts/hideScrollbars.js';
|
|
3
|
+
import setCustomCss from '../clientSideScripts/setCustomCss.js';
|
|
4
|
+
import { CUSTOM_CSS_ID } from './constants.js';
|
|
5
|
+
import { getAddressBarShadowPadding, getToolBarShadowPadding, waitFor } from './utils.js';
|
|
6
|
+
import getEnrichedInstanceData from '../methods/instanceData.js';
|
|
7
|
+
import hideRemoveElements from '../clientSideScripts/hideRemoveElements.js';
|
|
8
|
+
import toggleTextTransparency from '../clientSideScripts/toggleTextTransparency.js';
|
|
9
|
+
import waitForFonts from '../clientSideScripts/waitForFonts.js';
|
|
10
|
+
const log = logger('@wdio/visual-service:beforeScreenshot');
|
|
11
|
+
/**
|
|
12
|
+
* Methods that need to be executed before a screenshot will be taken
|
|
13
|
+
*/
|
|
14
|
+
export default async function beforeScreenshot(browserInstance, options, addShadowPadding = false) {
|
|
15
|
+
const { browserName, nativeWebScreenshot } = options.instanceData;
|
|
16
|
+
const { isAndroid, isIOS, isMobile } = browserInstance;
|
|
17
|
+
const { addressBarShadowPadding, disableBlinkingCursor, disableCSSAnimation, enableLayoutTesting, hideElements, noScrollBars, removeElements, toolBarShadowPadding, waitForFontsLoaded, } = options;
|
|
18
|
+
const addressBarPadding = getAddressBarShadowPadding({
|
|
19
|
+
browserName,
|
|
20
|
+
isAndroid,
|
|
21
|
+
isIOS,
|
|
22
|
+
isMobile,
|
|
23
|
+
nativeWebScreenshot,
|
|
24
|
+
addressBarShadowPadding,
|
|
25
|
+
addShadowPadding,
|
|
26
|
+
});
|
|
27
|
+
const toolBarPadding = getToolBarShadowPadding({ isAndroid, isIOS, isMobile, browserName, toolBarShadowPadding, addShadowPadding });
|
|
28
|
+
// Wait for the fonts to be loaded
|
|
29
|
+
if (waitForFontsLoaded) {
|
|
30
|
+
try {
|
|
31
|
+
await browserInstance.execute(waitForFonts);
|
|
32
|
+
}
|
|
33
|
+
catch (e) {
|
|
34
|
+
log.debug('Waiting for fonts to load threw an error:', e);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
// Hide the scrollbars
|
|
38
|
+
if (noScrollBars) {
|
|
39
|
+
await browserInstance.execute(hideScrollBars, noScrollBars);
|
|
40
|
+
}
|
|
41
|
+
// Hide and or Remove elements
|
|
42
|
+
if (hideElements.length > 0 || removeElements.length > 0) {
|
|
43
|
+
try {
|
|
44
|
+
await browserInstance.execute(hideRemoveElements, { hide: hideElements, remove: removeElements }, true);
|
|
45
|
+
}
|
|
46
|
+
catch (e) {
|
|
47
|
+
log.warn('\x1b[33m%s\x1b[0m', `
|
|
48
|
+
#####################################################################################
|
|
49
|
+
WARNING:
|
|
50
|
+
(One of) the elements that needed to be hidden or removed could not be found on the
|
|
51
|
+
page and caused this error
|
|
52
|
+
Error: ${e}
|
|
53
|
+
We made sure the test didn't break.
|
|
54
|
+
#####################################################################################
|
|
55
|
+
`);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
// Set some custom css
|
|
59
|
+
if (disableCSSAnimation || disableBlinkingCursor || browserInstance.isMobile) {
|
|
60
|
+
await browserInstance.execute(setCustomCss, { addressBarPadding, disableBlinkingCursor, disableCSSAnimation, id: CUSTOM_CSS_ID, toolBarPadding });
|
|
61
|
+
// Wait at least 500 milliseconds to make sure the css is applied
|
|
62
|
+
// Not every device is fast enough to apply the css faster
|
|
63
|
+
await waitFor(500);
|
|
64
|
+
}
|
|
65
|
+
// Make all text transparent
|
|
66
|
+
if (enableLayoutTesting) {
|
|
67
|
+
await browserInstance.execute(toggleTextTransparency, enableLayoutTesting);
|
|
68
|
+
// Wait at least 500 milliseconds to make sure the css is applied
|
|
69
|
+
// Not every device is fast enough to apply the css faster
|
|
70
|
+
await waitFor(500);
|
|
71
|
+
}
|
|
72
|
+
// Get all the needed instance data
|
|
73
|
+
const instanceOptions = {
|
|
74
|
+
addressBarShadowPadding: options.addressBarShadowPadding,
|
|
75
|
+
toolBarShadowPadding: options.toolBarShadowPadding,
|
|
76
|
+
...options.instanceData,
|
|
77
|
+
};
|
|
78
|
+
return getEnrichedInstanceData(browserInstance, instanceOptions, addShadowPadding);
|
|
79
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"beforeScreenshot.test.d.ts","sourceRoot":"","sources":["../../src/helpers/beforeScreenshot.test.ts"],"names":[],"mappings":""}
|