From a53974afd63940e0cfbe83a033ac3995dc9977ed Mon Sep 17 00:00:00 2001 From: chinmay-browserstack <92926953+chinmay-browserstack@users.noreply.github.com> Date: Thu, 25 Jul 2024 18:43:08 +0530 Subject: [PATCH] Change behaviour of enable JS to prioritise options passed (#1001) * Change behaviour of enable JS to prioritize options passed * Added tests --- src/snapshots.js | 3 ++- test/.storybook/snapshot.stories.js | 3 ++- test/storybook.test.js | 18 ++++++++++++++++++ 3 files changed, 22 insertions(+), 2 deletions(-) diff --git a/src/snapshots.js b/src/snapshots.js index 35f10a73..c97d6d07 100644 --- a/src/snapshots.js +++ b/src/snapshots.js @@ -208,7 +208,8 @@ export async function* takeStorybookSnapshots(percy, callback, { baseUrl, flags // separate story and snapshot options let { id, args, globals, queryParams, ...options } = snapshots[0]; - if (flags.dryRun || options.enableJavaScript || percy.config.snapshot.enableJavaScript) { + const enableJavaScript = options.enableJavaScript ?? percy.config.snapshot.enableJavaScript; + if (flags.dryRun || enableJavaScript) { log.debug(`Loading story via previewResource: ${options.name}`); // when dry-running or when javascript is enabled, use the preview dom options.domSnapshot = previewResource.content; diff --git a/test/.storybook/snapshot.stories.js b/test/.storybook/snapshot.stories.js index 90a479da..f45930ad 100644 --- a/test/.storybook/snapshot.stories.js +++ b/test/.storybook/snapshot.stories.js @@ -18,7 +18,8 @@ export const First = () => ( First.parameters = { percy: { - domTransformation: '(documentElement) => { documentElement.querySelectorAll(".removeMe").forEach(ele => ele.remove()); }' + domTransformation: '(documentElement) => { documentElement.querySelectorAll(".removeMe").forEach(ele => ele.remove()); }', + enableJavascript: false // this should be priotised over global config } } export const Second = () => ( diff --git a/test/storybook.test.js b/test/storybook.test.js index 4a42d43a..88605b85 100644 --- a/test/storybook.test.js +++ b/test/storybook.test.js @@ -333,6 +333,24 @@ describe('percy storybook', () => { expect(callArgs[1][0].domSnapshot).toEqual(previewDOM); }); + it('uses the preview dom when javascript is enabled', async () => { + fs.writeFileSync('.percy.yml', [ + 'version: 2', + 'snapshot:', + ' enableJavaScript: true' + ].join('\n')); + + // eslint-disable-next-line import/no-extraneous-dependencies + let { Percy } = await import('@percy/core'); + spyOn(Percy.prototype, 'snapshot').and.callThrough(); + + await storybook(['http://localhost:9000', '--include=First', '--verbose']); + + expect(logger.stderr).toEqual(jasmine.arrayContaining([ + '[percy:storybook] Loading story: Snapshot: First' + ])); + }); + it('removes element when domTransformation is passed', async () => { // eslint-disable-next-line import/no-extraneous-dependencies let { Percy } = await import('@percy/core');