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

test(e2e): store images in jpeg format #2451

Merged
merged 28 commits into from
Sep 16, 2024
Merged

test(e2e): store images in jpeg format #2451

merged 28 commits into from
Sep 16, 2024

Conversation

fshovchko
Copy link
Contributor

Closes: #2393

@fshovchko fshovchko added enhancement Improvements and additions to code needs review The PR is waiting for review e2e labels Jun 5, 2024
@fshovchko fshovchko requested review from a team June 5, 2024 17:30
@fshovchko fshovchko self-assigned this Jun 5, 2024
@fshovchko fshovchko requested review from dshovchko, ala-n and yadamskaya and removed request for a team June 5, 2024 17:30
@fshovchko fshovchko requested a review from dshovchko June 6, 2024 16:09
@ala-n
Copy link
Collaborator

ala-n commented Jun 7, 2024

It is definitely an enhancement that we can use, as we will get files that are practically smaller.
However, it does not utilize the possibility of WebP compression. It improves the file size just because PNG compression that sharp uses by default is better compared to the raw PNG output that pupiter gives out of the box. So, we still store snapshots as PNGs, just with compression (a similar result can be achieved by using the sharp wrapper on top of the screenshot function screenshots.push(await sharp(await page.screenshot(options)).png().toBuffer());).

To summarize everything, I'd have to say:

  1. The sharp library is definitely a good start, and we can leave it in the codebase with 100% confidence. (Just add a note in the README that it may require npm install --include=optional sharp -g to work properly in some cases.)

  2. We can definitely transform this PR into a partial solution that provides compression, which is a valuable and valid improvement (just without WebP until it actually affects file format to store).

  3. Regarding Dima's comment above, I'm not sure that lossy compression should be a problem unless it consistently gives us the same result. We are definitely not going to catch some color problems with the image, so unless compress(snapshot) = compress(actual) is valid for approximate similarity, we are fine.

  4. Regarding the original ticket with WebP, here are some notes to move forward:

    • Snapshot storing is a jest part of the process.
    • It happens inside the matching library, specifically at the toMatchImageSnapshot level. If I remember correctly, we can describe to Jest itself how to store a snapshot, so we might not need to override jest-image-snapshot since it utilizes Jest's original snapshotting. But it still should be a little bit tricky thing to do as I mentioned initially.

@ala-n ala-n added under discussion and removed needs review The PR is waiting for review labels Jun 7, 2024
Copy link
Collaborator

@dshovchko dshovchko left a comment

Choose a reason for hiding this comment

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

If compression is ok for us I vote for storing images in AVIF format. AVIF has higher compression efficiency than WebP.

@ala-n
Copy link
Collaborator

ala-n commented Jun 7, 2024

If compression is ok for us, I vote for storing images in AVIF format. AVIF has higher compression efficiency than WebP.

This is a totally valid suggestion. If sharp (or another image processor) can work with AVIF (approximately fast), we can use it. I'll update the original ticket.

@fshovchko fshovchko requested a review from dshovchko June 14, 2024 14:59
@fshovchko fshovchko added the needs review The PR is waiting for review label Jul 4, 2024
ala-n added 2 commits August 19, 2024 03:09
# Conflicts:
#	e2e/package.json
#	e2e/tests/__image_snapshots__/homepage-feature-feature-homepage-looks-fine-test-homepage-footer-on-desktop-1-snap.png
#	e2e/tests/__image_snapshots__/homepage-feature-feature-homepage-looks-fine-test-homepage-footer-on-mobile-1-snap.png
#	package-lock.json
e2e/setup/serializers/image/image-processor.ts Outdated Show resolved Hide resolved
e2e/reporters/reporter.js Outdated Show resolved Hide resolved
e2e/reporters/reporter.js Outdated Show resolved Hide resolved
e2e/setup/serializers/image/utils/name.ts Outdated Show resolved Hide resolved
e2e/setup/serializers/image/diff-builder.ts Outdated Show resolved Hide resolved
e2e/setup/scenarios.screenshot.ts Show resolved Hide resolved
e2e/reporters/reporter.js Show resolved Hide resolved
@ala-n ala-n requested review from dshovchko and NastaLeo September 12, 2024 15:03
@fshovchko fshovchko requested a review from ala-n September 12, 2024 21:16
fshovchko and others added 3 commits September 13, 2024 15:31
# Conflicts:
#	e2e/package.json
#	e2e/tests/__image_snapshots__/homepage-feature-feature-homepage-looks-fine-test-homepage-footer-on-desktop-1-snap.png
#	e2e/tests/__image_snapshots__/homepage-feature-feature-homepage-looks-fine-test-homepage-screen-1-snap.png
#	e2e/tests/__image_snapshots__/homepage-feature-feature-homepage-looks-fine-test-homepage-screen-on-mobile-1-snap.png
#	package-lock.json
codeclimate[bot]

This comment was marked as outdated.

@ala-n ala-n changed the base branch from main to main-beta September 13, 2024 16:15
@exadel-inc exadel-inc deleted a comment from codeclimate bot Sep 13, 2024
@ala-n ala-n merged commit 139b891 into main-beta Sep 16, 2024
7 checks passed
@ala-n ala-n deleted the e2e/webp branch September 16, 2024 11:51
@github-actions github-actions bot locked and limited conversation to collaborators Sep 16, 2024
@ala-n
Copy link
Collaborator

ala-n commented Sep 19, 2024

🎉 This PR is included in version 5.0.0-beta.34 🎉

The release is available on:

Your semantic-release bot 📦🚀

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
e2e enhancement Improvements and additions to code needs review The PR is waiting for review released
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[⚡e2e]: ability to store image snapshots as a WebP/AVIF
6 participants