Use the Force and automate React app checks
data:image/s3,"s3://crabby-images/aa9f3/aa9f393820fa31de6c73206a489808f137b95261" alt=""
$ whoami
Senior Software Engineer
The most important:
I like JavaScript, React, movies, music and I'm a big fan of LOTR and Star Wars 🤓
May the Force be with you!
6 years at GlobalLogic
about 8 years in Web Development
Speaker and mentor at GL JS community
Speaker and part of the program committee at Fwdays conference
data:image/s3,"s3://crabby-images/ec6b9/ec6b9a4c98639eb05a22d414654afc554b1fed02" alt=""
data:image/s3,"s3://crabby-images/717b4/717b48c96ad366ba44a837bb93a5962911f7effd" alt=""
Inna Ivashchuk
Motivation
data:image/s3,"s3://crabby-images/ba6e5/ba6e5ce307296df6080ccf9d546feed952508452" alt=""
1
Development process
data:image/s3,"s3://crabby-images/279e1/279e1e0df115948d6c806d6fc65a2741cd29f130" alt=""
data:image/s3,"s3://crabby-images/cfe47/cfe4715c38899cb8259c89ddbf13897b2d87ab1a" alt=""
data:image/s3,"s3://crabby-images/31215/31215c08a359509d66ecec41f45419ecf93dfad1" alt=""
data:image/s3,"s3://crabby-images/3e548/3e5487a26dac6fe8668ea46cc450ee1d21fa6aa2" alt=""
QA
devs
changes
existing features are broken
changes
data:image/s3,"s3://crabby-images/f780d/f780daf740d27ec7e454c1a463a08bb6611fa13e" alt=""
broken styles
changes
2
Worst scenario
data:image/s3,"s3://crabby-images/279e1/279e1e0df115948d6c806d6fc65a2741cd29f130" alt=""
data:image/s3,"s3://crabby-images/cfe47/cfe4715c38899cb8259c89ddbf13897b2d87ab1a" alt=""
data:image/s3,"s3://crabby-images/31215/31215c08a359509d66ecec41f45419ecf93dfad1" alt=""
data:image/s3,"s3://crabby-images/3e548/3e5487a26dac6fe8668ea46cc450ee1d21fa6aa2" alt=""
QA
devs
changes
data:image/s3,"s3://crabby-images/f780d/f780daf740d27ec7e454c1a463a08bb6611fa13e" alt=""
lovely feature doesn't work
2
data:image/s3,"s3://crabby-images/f0891/f08913ead9bf9ff41557da6106ddb81ecddd30c6" alt=""
users
changes
But what, if we can catch them earlier?
data:image/s3,"s3://crabby-images/9e499/9e499ff6bf6a240e19f5e247b81c66582d7f9e91" alt=""
3
Code style and quality (linter, prettier)
data:image/s3,"s3://crabby-images/47a4d/47a4d296f360a7d64fe61e2155b7325253a993d9" alt=""
4
Code style
data:image/s3,"s3://crabby-images/279e1/279e1e0df115948d6c806d6fc65a2741cd29f130" alt=""
data:image/s3,"s3://crabby-images/31215/31215c08a359509d66ecec41f45419ecf93dfad1" alt=""
vs.
double quotes
spaces
tabs
single quotes
...
...
npm
yarn
5
Code style guide and code formatter
data:image/s3,"s3://crabby-images/7e9e7/7e9e70e11803c849f6466402d935ad00b1692574" alt=""
Define code style guide doc
and the next step is to install, set up and use
data:image/s3,"s3://crabby-images/1eb49/1eb4922b538a812f6fc7edc64d90ecb4d291c169" alt=""
6
What is Prettier? ?
data:image/s3,"s3://crabby-images/7e9e7/7e9e70e11803c849f6466402d935ad00b1692574" alt=""
And why?
An opinionated code formatter
Supports many languages
You press save and code is formatted
Integrates with most editors
No need to discuss style in code review
Saves you time and energy
7
To format and check
npx prettier --write .
To format all files with Prettier:
npx prettier --check .
If CI configured, next command can be in use:
10
Code analysis tools
data:image/s3,"s3://crabby-images/c7cf2/c7cf20c4e9ce62acbb9c1d436381e351c06895d2" alt=""
data:image/s3,"s3://crabby-images/37a1e/37a1e23cbf9bf3c43a94d196575496bf693247ba" alt=""
data:image/s3,"s3://crabby-images/6b755/6b7558e17a9af824e02202a06bf631bd369083cb" alt=""
data:image/s3,"s3://crabby-images/111d1/111d150a44314e4c78f3a93e06f83ab76f2467f3" alt=""
data:image/s3,"s3://crabby-images/0082f/0082f7a2dedb15c6f260c45a8ba0a3b0f97e1f7b" alt=""
11
data:image/s3,"s3://crabby-images/126f7/126f7c07f4136c834dcdd270a1c5330f76525f65" alt=""
deprecated
deprecated
data:image/s3,"s3://crabby-images/eee0f/eee0ffbee6fb2e2364aaf3f7b91b3fc287fa3052" alt=""
Would be good to add a new lint command to the scripts in package.json
const nums = [10, 20, 100];
for (let i=0; i < nums.length; i++) {
console.log(nums[i]);
}
14
eslint configuration example
{
"settings":{
"react":{
"version":"17.0.2"
}
},
"env":{
"browser":true,
"es2021":true,
"jest":true
},
"extends":[
"plugin:react/recommended",
"standard"
],
"parserOptions":{
"ecmaFeatures":{
"jsx":true
},
"ecmaVersion":"latest",
"sourceType":"module"
},
"plugins":[
"react"
],
"rules":{
"arrow-parens":[
"error",
"as-needed"
],
"comma-dangle":"off",
"import/no-extraneous-dependencies":[
"error",
{
"devDependencies":[
"**/*.test.js",
"**/*.spec.js"
]
}
],
"indent":[
"error",
"tab",
{
"SwitchCase":1
}
],
"linebreak-style":0,
"no-console":[
"error",
{
"allow":[
"info",
"warn",
"error"
]
}
],
"no-tabs":"off",
"react/prefer-es6-class":0,
"react/jsx-indent":[
"error",
"tab"
],
"react/jsx-indent-props":[
"error",
"tab"
],
"react/jsx-filename-extension":[
1,
{
"extensions":[
".js"
]
}
],
"react/no-unused-prop-types":[
2,
{
"skipShapeProps":true
}
],
"react/react-in-jsx-scope":"off",
"react/forbid-prop-types":[
0
],
"react/require-extension":"off",
"semi":[
2,
"always"
],
"space-before-function-paren":"off"
}
}
14
“Sir, it’s quite possible this app is not entirely stable.”
data:image/s3,"s3://crabby-images/ae7e2/ae7e2738366f781e50acd5ce622f93c6e8ea12c4" alt=""
15
Be good and write tests
data:image/s3,"s3://crabby-images/f880e/f880ec8ff5a68fa83e815e068663f0779d31282c" alt=""
16
data:image/s3,"s3://crabby-images/eee0f/eee0ffbee6fb2e2364aaf3f7b91b3fc287fa3052" alt=""
End to End (e2e)
Integration
Unit
A helper robot that behaves like a user to click around the app and verify that it functions correctly
Verify that several units work together in garmony
Verify that individual isolated parts work as expected
17
data:image/s3,"s3://crabby-images/df09f/df09f16fa570d196ce0e90e5e5d1c7a7c49a4c57" alt=""
data:image/s3,"s3://crabby-images/5ced7/5ced7537afd17bc43a1b56e9c1b646807a6d6294" alt=""
data:image/s3,"s3://crabby-images/92bfc/92bfcb3d544f15df5ab6aa7d295aa4fc094ebca8" alt=""
data:image/s3,"s3://crabby-images/7f4d6/7f4d663401b451cef09e20d490420307bc13a7e1" alt=""
data:image/s3,"s3://crabby-images/e41b0/e41b07bbf65c75ea4461422d929b742cacc49ab8" alt=""
Testing Library
data:image/s3,"s3://crabby-images/06cb6/06cb6ceca8959d0229d961af4ca14801855ea25a" alt=""
Playwright
18
data:image/s3,"s3://crabby-images/eee0f/eee0ffbee6fb2e2364aaf3f7b91b3fc287fa3052" alt=""
Recommended Tools by React team
- Jest is a JavaScript test runner that lets you access the DOM via jsdom. If you use Create React App, Jest is already included out of the box with useful defaults.
- React Testing Library is a set of helpers that let you test React components without relying on their implementation details.
data:image/s3,"s3://crabby-images/e41b0/e41b07bbf65c75ea4461422d929b742cacc49ab8" alt=""
data:image/s3,"s3://crabby-images/ac4a5/ac4a5f422526543726a483962450865865e7e05b" alt=""
20
21
What is left? Just to start writing tests ;)
data:image/s3,"s3://crabby-images/d48e4/d48e44a525c26921b1598a80761b7aaa87721604" alt=""
Time to use the Force and to automate all checks
data:image/s3,"s3://crabby-images/26b1e/26b1e7201f5cf6bd5b57ee872d8d4bcb907b6dfa" alt=""
22
CI/CD practices - our Force
data:image/s3,"s3://crabby-images/13c09/13c0933c3a9b174cb80067da6781d4ca0ffda039" alt=""
23
data:image/s3,"s3://crabby-images/22758/227580224eb08cf2dd328cd994876b9655565e93" alt=""
data:image/s3,"s3://crabby-images/dd2c2/dd2c211e1d4e2f124631dd4c398fb8a2c6f44dbf" alt=""
data:image/s3,"s3://crabby-images/63afd/63afd6348194308d915e998035a3bb6176ee9f8d" alt=""
data:image/s3,"s3://crabby-images/af5f2/af5f22a76c5fc0a5e7e3d6e971f96e352c10151a" alt=""
data:image/s3,"s3://crabby-images/f0ded/f0ded8f7b5554ef4789f905481669501bc689cf6" alt=""
data:image/s3,"s3://crabby-images/3fb4f/3fb4f56d60bc30b1b6da83df4df368f8714ae73e" alt=""
24
data:image/s3,"s3://crabby-images/eee0f/eee0ffbee6fb2e2364aaf3f7b91b3fc287fa3052" alt=""
What is CI/CD?
data:image/s3,"s3://crabby-images/94ffd/94ffde8a5f5bf37609d0019186a3bd780a4e8d3e" alt=""
25
Continuous Integration
data:image/s3,"s3://crabby-images/279e1/279e1e0df115948d6c806d6fc65a2741cd29f130" alt=""
data:image/s3,"s3://crabby-images/cfe47/cfe4715c38899cb8259c89ddbf13897b2d87ab1a" alt=""
build
checks
dev
artifact
data:image/s3,"s3://crabby-images/55503/55503bc441538cb216e8fd3edf4222de5d107832" alt=""
CI
VCS
(static files)
26
Continuous Delivery/Deployment
data:image/s3,"s3://crabby-images/cfe47/cfe4715c38899cb8259c89ddbf13897b2d87ab1a" alt=""
artifact
CD
data:image/s3,"s3://crabby-images/ccb68/ccb68fd6023a6fe7f145ccb5e8c21fdbd165529b" alt=""
data:image/s3,"s3://crabby-images/29dc2/29dc21e8b1bc17a9bc535aa6483e37d1ff3db7ba" alt=""
data:image/s3,"s3://crabby-images/6822f/6822f878010515bfe6642e83adf49c48ba25d365" alt=""
data:image/s3,"s3://crabby-images/cfe47/cfe4715c38899cb8259c89ddbf13897b2d87ab1a" alt=""
data:image/s3,"s3://crabby-images/ccb68/ccb68fd6023a6fe7f145ccb5e8c21fdbd165529b" alt=""
QA/dev stage
production
(static files)
27
Continuous Integration vs Continuous Delivery vs Continuous Deployment
data:image/s3,"s3://crabby-images/a565d/a565d5ba3f0b411ae6d245ab2ef058991ebe8afb" alt=""
28
What about incomplete features?
Use feature flags so that incomplete features do not affect customers in production (Launch Darkly service)
data:image/s3,"s3://crabby-images/12a3a/12a3a971958cb43e265fbcf8c3ee7c36212ddcab" alt=""
29
Note: environment variables can be used, but it's a bit more tricky to maintain
Let's proceed with
GitHub Actions as our
CI/CD platform
data:image/s3,"s3://crabby-images/1c1f3/1c1f33f24bcfb727dfde37d8ffea24c098b0bd3c" alt=""
30
GitHub Actions makes it easy to automate
data:image/s3,"s3://crabby-images/faf3a/faf3afab6c574aa003768454e7de95026f06c7ca" alt=""
31
GitHub Actions advantages
Built into GitHub
Multiple templates for all kind of CI
Ability to create your own template and publish them as an Action
Completely free for open-source repos
2000 free build minutes per month for private repos
32
GitHub Actions workflow, as a core concept
A workflow is a configurable automated process that will run one or more jobs. Workflows are defined by a YAML file checked in to your repository and will run when triggered by an event in your repository, or they can be triggered manually, or at a defined schedule.
data:image/s3,"s3://crabby-images/afc80/afc80bdbb80d3ead170f5eca1e1e849dbfdbf9cc" alt=""
33
How to configure a workflow template?
data:image/s3,"s3://crabby-images/44bfb/44bfb138dcd13d47cf4e3182744295ebd7c17368" alt=""
34
Step 1
On the main page of your repository navigate to Actions.
data:image/s3,"s3://crabby-images/a572c/a572ccf61ccc939faafbb5a7c09c5dd235d9f6bf" alt=""
35
Step 2
Pick a template you would like to use and click Set up this workflow
data:image/s3,"s3://crabby-images/9e720/9e720d215ee77a7c1072518006e98cfe73b3c3dc" alt=""
36
Step 3
We can make changes in the editor and commit the action to your repository using the Start commit button
data:image/s3,"s3://crabby-images/b0a46/b0a46e31cc86d287e26df2633674beb26dad2cd3" alt=""
37
Adding an Action template to the workflow:
We can use an existing Action or even publish our own
data:image/s3,"s3://crabby-images/d26bd/d26bd935151c412a95c439050e04cb8fabddc37f" alt=""
38
A Workflow example to run React app checks
name: run-checks
on:
push:
branches: [main]
jobs:
checks:
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [16.x]
steps:
- uses: actions/checkout@v2
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v1
with:
node-version: ${{ matrix.node-version }}
- run: npm ci
- name: Run linter
run: npm run lint
- name: Run all tests
run: npm test
39
And one more useful tool -Husky
data:image/s3,"s3://crabby-images/1f500/1f50043132b070941d478d7675b43e5591c46717" alt=""
40
Git hooks: Husky
data:image/s3,"s3://crabby-images/9210c/9210c2798c92aeba35cb850dfbea291850997f55" alt=""
41
Husky improves your commits and more
You can use it to lint your commit messages, run tests, lint code, etc... when you commit or push. Husky supports all Git hooks.
42
Why I like Husky
43
Runs checks on every commit locally
Zero dependencies and lightweight
Easy to install
Follows npm and Yarn best practices regarding autoinstall
User-friendly messages
The Workflow and all checks are ready.
It's time for the Demo
data:image/s3,"s3://crabby-images/62165/62165f4376d2111a039b0e76ae25c9b2ac9c83b4" alt=""
The demo is in progress...
44
Questions time
data:image/s3,"s3://crabby-images/9a53d/9a53dd5a48156cef6b2c43c4d4d782cdd6a9b0ca" alt=""
45
In the world of web development,
Where React reigns supreme,
CI/CD tools are the key,
To ensure our app is a dream.
*
With checks and builds and tests,
We automate our release,
Deploying with ease and confidence,
Knowing our app won't cease.
*
React components are checked,
For errors and for flaws,
With every commit and pull request,
Ensuring our code complies with laws.
ChatGPT
data:image/s3,"s3://crabby-images/97ac2/97ac282063f0c5112466c93adb51b1b1680d91f6" alt=""
Links:
data:image/s3,"s3://crabby-images/d52ff/d52ff715d4abb4d3f39176982ba878aaebe81a3f" alt=""
data:image/s3,"s3://crabby-images/bb12e/bb12eb8190ebaf2ae8ed7321730649a29b0e6e62" alt=""
47
Thank you!
data:image/s3,"s3://crabby-images/c136b/c136b7a15c08045fb7ad4fa539042dc534947c78" alt=""
46
Use the Force and automate React app checks ready
By Inna Ivashchuk
Use the Force and automate React app checks ready
Long story short
- 651