mirror of
https://github.com/zoriya/react-native-svg.git
synced 2025-12-05 22:56:11 +00:00
<!-- Thanks for submitting a pull request! We appreciate you spending the time to work on these changes. Please follow the template so that the reviewers can easily understand what the code changes affect --> # Summary This PR adds E2E tests based on view screenshots done via `react-native-view-shot`. It only works with devices that have their [pixel ratio](https://reactnative.dev/docs/pixelratio) equal `3`. If you want to use device with different pixel ratio, you need to adjust it in `e2e/generateReferences.ts` viewport and regenerate reference images (see below). Steps to run tests: - Run Metro server for example app via `yarn start` in example app's directory - Run `example` app on platform of your choice (currently only Android & iOS are supported) via `yarn android` or `yarn ios` in example app's directory - Run `yarn e2e` in project's root directory to start Jest server - Select `E2E` tab in example app - Wait for tests to finish - You can see test results, as well as diffs (actual rendered svg vs reference image) in `e2e/diffs` directory Steps to add new test cases: - Put SVG of your choice to `e2e/cases` directory - Run `yarn generateE2eRefrences`, this will open headless chrome browser via `puppeteer` and snapshot all rendered SVGs to .png files and later use them as reference in tests - You should see new .png files in `e2e/references` - When you run E2E tests again, it will use new test case(s) you've added ## Test Plan https://github.com/software-mansion/react-native-svg/assets/41289688/24ee5447-ce9a-43b6-9dde-76229d25a30a https://github.com/software-mansion/react-native-svg/assets/41289688/71d1873f-8155-4494-80bd-e4c1fa72a065 ### What's required for testing (prerequisites)? See Summary ### What are the steps to reproduce (after prerequisites)? See Summary ## Compatibility | OS | Implemented | | ------- | :---------: | | iOS | ✅ | | Android | ✅ | | Web | ❌ | ## Checklist <!-- Check completed item, when applicable, via: [X] --> - [X] I have tested this on a device and a simulator - [x] I added documentation in `README.md` - [X] I updated the typed files (typescript) - [X] I added a test for the API in the `__tests__` folder --------- Co-authored-by: bohdanprog <bohdan.artiukhov@swmansion.com> Co-authored-by: Jakub Grzywacz <jakub.grzywacz@swmansion.com>
43 lines
1.1 KiB
JSON
43 lines
1.1 KiB
JSON
{
|
|
"name": "web-example",
|
|
"main": "index.js",
|
|
"version": "0.0.1",
|
|
"scripts": {
|
|
"start": "expo start --web",
|
|
"reset-project": "node ./scripts/reset-project.js",
|
|
"test": "jest --watchAll",
|
|
"lint": "expo lint"
|
|
},
|
|
"jest": {
|
|
"preset": "jest-expo"
|
|
},
|
|
"dependencies": {
|
|
"@expo/vector-icons": "^14.0.2",
|
|
"@react-navigation/native": "^6.0.2",
|
|
"expo": "~51.0.2",
|
|
"expo-asset": "~10.0.10",
|
|
"react": "18.2.0",
|
|
"react-dom": "18.2.0",
|
|
"react-native": "0.74.0",
|
|
"react-native-reanimated": "3.13.0",
|
|
"react-native-svg": "link:../",
|
|
"react-native-svg-transformer": "^1.4.0",
|
|
"react-native-view-shot": "3.8.0",
|
|
"react-native-web": "0.19.11"
|
|
},
|
|
"devDependencies": {
|
|
"@babel/core": "^7.20.0",
|
|
"@expo/metro-runtime": "~3.2.1",
|
|
"@react-native/metro-config": "^0.74.85",
|
|
"@types/jest": "^29.5.12",
|
|
"@types/react": "~18.2.45",
|
|
"@types/react-test-renderer": "^18.0.7",
|
|
"jest": "^29.2.1",
|
|
"jest-expo": "~51.0.3",
|
|
"patch-package": "^8.0.0",
|
|
"react-test-renderer": "18.2.0",
|
|
"typescript": "~5.3.3"
|
|
},
|
|
"private": true
|
|
}
|