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

Using imageWithSmartInvert with isRecording = true/false - fails everytime #127

Closed
parikhparth23 opened this issue May 3, 2023 · 7 comments

Comments

@parikhparth23
Copy link

parikhparth23 commented May 3, 2023

I am using the imageWithSmartInvert with isRecording = true/false and the test always fails

assertSnapshot(matching: view, as: .imageWithSmartInvert)

My original image is:
original

when i run with isRecording=true it generated the Black/Golden image.
when i run it with isRecording=false the snapshot does not match reference.

.
.
.
failed - Snapshot does not match reference.

"/Users/abc/Library/Developer/CoreSimulator/Devices/ACC40F6C-1421-4D1B-9008-20C0EB7B81EE/data/Containers/Bundle/Application/14408B86-E69D-4390-9E8D-0A050D98F518/SmallAppHost.app/PlugIns/SnapshotTests.xctest/SnapshotTestsBundle.bundle/Snapshots/Tests/testLoading.1.png"
@+
"/Users/abc/Library/Developer/CoreSimulator/Devices/ACC40F6C-1421-4D1B-9008-20C0EB7B81EE/data/Containers/Data/Application/E4FA0EDE-9A8C-4B4A-9E7B-4FDDBDF81EDB/tmp/Tests/testLoading.1.png"

Newly-taken snapshot does not match reference.
.
.
.

i tried opening the image in above locations - both are same -
1
2

can you please have a look?

@parikhparth23
Copy link
Author

parikhparth23 commented May 3, 2023

attaching the images from xcresult:
difference_3_75227A15-33D8-4D2B-9FCA-46C3B457D1A5
failure_2_75227A15-33D8-4D2B-9FCA-46C3B457D1A5
reference_1_75227A15-33D8-4D2B-9FCA-46C3B457D1A5

zoom into the centre of the difference image (first image) and you will see the difference

@parikhparth23
Copy link
Author

the difference is
Screenshot 2023-05-03 at 11 52 14 AM

@NickEntin
Copy link
Collaborator

NickEntin commented May 3, 2023

Hi Parth! Can you provide some more details about what you're snapshotting? Is that a simple UIImageView in the center of the screen? If you have a branch adding a test case to AccessibilitySnapshot that reproduces the issue, that would greatly help me investigate what's going wrong.

@parikhparth23
Copy link
Author

parikhparth23 commented May 3, 2023

@NickEntin - i and @abinodhthomas have added a support to add the precision - https://github.com/parikhparth23/AccessibilitySnapshot/commit/ac8477631892330cbed2d0c93043267a1d5203e4
plz have a look and merge it.

@NickEntin
Copy link
Collaborator

If you're seeing this on subsequent runs on the same machine, it sounds like there's likely an underlying issue going on here. While adding precision might work around it, I'd like to see if we can figure out the root problem first. Can you provide a code sample that reproduces the issue?

@parikhparth23
Copy link
Author

parikhparth23 commented May 11, 2023

@NickEntin i wish i could share the code or even a snippet. the code is a proprietary code.
i tried creating a sample app and it works without any issue.
do you mind merging the precision code to your repo? - if you do it i will be able to use this framework. And i will look into our code base why the image is failing.

the precision value by default is to match 100% - so it wont affect the existing or future users.

And i just confirmed with our team the photos above is not an image- it is actually drawing the circles in code.

so this is not a bug.

do you mind adding the precision PR to your branch please?

@NickEntin
Copy link
Collaborator

There is now tolerance parameters available when using FBSnapshotTestCase as the snapshotting engine. Support for SnapshotTesting is tracked by #63.

That said, I would highly recommend looking into why your views are not able to pass consecutive snapshots on the same machine and only use precision for inter-machine comparison failures. Perhaps you need to disable animations, or something along those lines? The framework is not designed to support snapshotting non-deterministic rendering views.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants