Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add visual tests support #5456

Merged
merged 4 commits into from
Feb 23, 2023
Merged

Add visual tests support #5456

merged 4 commits into from
Feb 23, 2023

Conversation

geriux
Copy link
Contributor

@geriux geriux commented Feb 7, 2023

Related PRs:

Description

This PR adds the setup to be able to have visual tests, the idea is to start migrating the manual test we currently do each release and to also start expanding our test suites, like testing themes and important components like RichText.

We will be using two new libraries, jest-image-snapshot which enables us to compare two images using Jest. It compares the baseline image against the new one generated on CI, if the difference is over the threshold it will mark the test as failed and it will return the difference output as base64 in the console, this will be handy to check quickly what's breaking.

The other library is jimp which will be used to edit the screenshots taken using Appium, mostly to remove the status bar, resize and reduce quality.

As you'll see in the files changed and in the new tests, we just need to write them as we were doing for the other E2E tests, to match a visual change we'll just need to do:

const screenshot = await takeScreenshot();
expect( screenshot ).toMatchImageSnapshot();

To test CI checks should pass.

PR submission checklist:

  • I have considered adding unit tests where possible.
  • I have considered if this change warrants user-facing release notes more info and have added them to RELEASE-NOTES.txt if necessary.

@geriux geriux added the Testing Anything related to automated tests label Feb 7, 2023
@fluiddot
Copy link
Contributor

fluiddot commented Feb 8, 2023

@geriux Seems we'd need to tweak the CI job configuration to address the following error in Test Android on Device - Full:

EACCES: permission denied, mkdir '/home/circleci/project/__device-tests__/__image_snapshots__/__diff_output__'

__device-tests__/utils.js Outdated Show resolved Hide resolved
@peril-wordpress-mobile
Copy link

peril-wordpress-mobile bot commented Feb 8, 2023

Wanna run full suite of Android and iOS UI tests? Click here and 'Approve' CI job!

@geriux geriux force-pushed the add-visual-tests-support branch from 2de83f7 to a2ab57c Compare February 8, 2023 17:14
@geriux
Copy link
Contributor Author

geriux commented Feb 8, 2023

@geriux Seems we'd need to tweak the CI job configuration to address the following error in Test Android on Device - Full:

Yup we needed to create the directory for the snapshot difference output, I included it in a2ab57c

@geriux geriux added this to the 1.89.0 (21.8) milestone Feb 8, 2023
@geriux geriux marked this pull request as ready for review February 8, 2023 17:59
@geriux geriux requested review from dcalhoun and fluiddot February 8, 2023 17:59
Copy link
Member

@dcalhoun dcalhoun left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks great!

.circleci/config.yml Outdated Show resolved Hide resolved
@geriux geriux modified the milestones: 1.89.0 (21.8), 1.90.0 (21.9) Feb 16, 2023
@geriux geriux force-pushed the add-visual-tests-support branch from 86a2046 to 1ed2a0f Compare February 20, 2023 10:43
@geriux
Copy link
Contributor Author

geriux commented Feb 20, 2023

Hey there 👋 I've just updated this PR as there were some conflicts. I think I've addressed all comments but please let me know if there are any other questions, thank you!

Copy link
Member

@dcalhoun dcalhoun left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looking forward to merging this. I left one question related to test clean up.

Additionally, what is the command used to run these tests locally?


// Visual test check
const screenshot = await takeScreenshot();
expect( screenshot ).toMatchImageSnapshot();
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I noticed the previous test has what appears to be clean up code removing the block. Should all tests including this one have that as well? This question applies to __device-tests__/gutenberg-editor-group-visual.test.js as well.

Suggested change
expect( screenshot ).toMatchImageSnapshot();
expect( screenshot ).toMatchImageSnapshot();
await editorPage.removeBlockAtPosition( blockNames.gallery );

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It will depend on the test, for this case, to start with a "blank" canvas in the second test you need to remove the blocks you created before, as the other tests in the file will run in the same session.

@dcalhoun
Copy link
Member

Additionally, what is the command used to run these tests locally?

Never mind. I was running the correct command locally: npm run device-tests:local -- gutenberg-editor-gallery-visual.test.js.

The errors I encountered locally related to the e2e tests' requirement of Xcode 13. I only had Xcode 14 installed. Installing Xcode 13 and sudo xcode-select -s /Applications/Xcode\ 13.app allowed me to run the new visual tests successfully. 🎉

@geriux
Copy link
Contributor Author

geriux commented Feb 22, 2023

Additionally, what is the command used to run these tests locally?

Never mind. I was running the correct command locally: npm run device-tests:local -- gutenberg-editor-gallery-visual.test.js.

The errors I encountered locally related to the e2e tests' requirement of Xcode 13. I only had Xcode 14 installed. Installing Xcode 13 and sudo xcode-select -s /Applications/Xcode\ 13.app allowed me to run the new visual tests successfully. 🎉

Glad you got it running! Yeah until we upgrade to Appium 2, we are stuck with the Xcode 13 issue, becuase SauceLabs currently doesn't support Appium 2 for simulators on Android.

@geriux geriux merged commit 15f4795 into trunk Feb 23, 2023
@geriux geriux deleted the add-visual-tests-support branch February 23, 2023 18:41
@dcalhoun dcalhoun mentioned this pull request Mar 2, 2023
4 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Testing Anything related to automated tests
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants