NodeJS #7
Practice time
$ whoami
Inna Ivashchuk
Senior Software Engineer
JS developer, music fan, movie-dependent and Star Wars fan 🤓
May the Force be with you!
data:image/s3,"s3://crabby-images/ec6b9/ec6b9a4c98639eb05a22d414654afc554b1fed02" alt=""
data:image/s3,"s3://crabby-images/717b4/717b48c96ad366ba44a837bb93a5962911f7effd" alt=""
Agenda
-
Nowadays development process
-
Practice time
Nowadays development process
data:image/s3,"s3://crabby-images/6f97e/6f97e9b81d30270baa16fb108bf70176e53c3a62" alt=""
Docker
+
Web Development in 2021
Nowadays SDLC with CI/CD, containers, orchestration and clouds
data:image/s3,"s3://crabby-images/fc5e7/fc5e7ce1740abcc3b8e1bd679f10addfd33ad25c" alt=""
data:image/s3,"s3://crabby-images/88e59/88e594c3fe1ff5367260514f7f9415cf378dc4af" alt=""
data:image/s3,"s3://crabby-images/7720f/7720fb8b6c9c16e50e4ba9174de4f83093d26591" alt=""
data:image/s3,"s3://crabby-images/5ccc1/5ccc19e4901ffffe0c802c7e45a45d775c7c700b" alt=""
data:image/s3,"s3://crabby-images/4c91f/4c91fdd1f327f27bedaa365f29f46f240149e739" alt=""
data:image/s3,"s3://crabby-images/ecd91/ecd919879683df5b0c72976a07eebfb5459b00bc" alt=""
Working in a Team
data:image/s3,"s3://crabby-images/9759a/9759a5039d9ffc4d4ffbc4bd6a388013dd599637" alt=""
Version System Control (VSC)
data:image/s3,"s3://crabby-images/5c624/5c624f91d27923e194275649d8f039702a2cd851" alt=""
Would be good to know:
- How to use Git
- How to create a Pull request
- What is Code review
data:image/s3,"s3://crabby-images/6c3e1/6c3e1d9101e7bcad8c9ab480d6f5cdecb9433ea2" alt=""
Pull Requests
How to push your local changes to a team's repository?
data:image/s3,"s3://crabby-images/973d3/973d3742247efab4ee57d8d931ea39edb353c541" alt=""
# fist - create a new branch
$ git checkout -b feat-my-new-user-form-and-ctrl
# next - commit your changes
$ git commit -m "feat(app): user form and controller"
# next - push your branch with changes
$ git push origin HEAD
# next - create a PR using GitHub
# next - request Code review
# final - merge your changes into main/master branch
Code review
Teammates will do a code review and can suggest how to improve your code, optimize solution or make it simpler
data:image/s3,"s3://crabby-images/3496d/3496df5cdfed111ada95eb241b53d56d14ea4683" alt=""
CI/CD
What is CI/CD?
data:image/s3,"s3://crabby-images/729fa/729fa80b8050f12bdbabc72250799ffd10dcd367" alt=""
Continuous Integration
build
checks
developer
artifact
data:image/s3,"s3://crabby-images/55503/55503bc441538cb216e8fd3edf4222de5d107832" alt=""
CI
VCS
(Docker image)
data:image/s3,"s3://crabby-images/b4fcf/b4fcf3b90d5621aecf3fe40474f2805bc95ad300" alt=""
data:image/s3,"s3://crabby-images/dadb8/dadb8a9e8a63c08053f38ad0293acc585797a918" alt=""
data:image/s3,"s3://crabby-images/05bdd/05bdd166c80ab574677ef6d88a2b821b531b2b12" alt=""
- set up the environment
- install required dependencies
CI: preparation
data:image/s3,"s3://crabby-images/8d30a/8d30a2d6e34991e226a26adb5a15a827895a7aac" alt=""
Code checks using TS Lint:
CI: checks
data:image/s3,"s3://crabby-images/1d914/1d9148598e5df159a6f54ef8adea3211c1e39b8a" alt=""
- code styles
- typos
- missing symbols
- etc
data:image/s3,"s3://crabby-images/85522/85522e699959a694fb9007cf9fa5167642721890" alt=""
CI: tests
Write and run tests is always a good idea
data:image/s3,"s3://crabby-images/73089/73089e5964fca17e8bae4ca12abb468a1c5ed984" alt=""
data:image/s3,"s3://crabby-images/86844/86844ec0247113a1aae10eff640b137b23878344" alt=""
Time to build our application:
CI: build
data:image/s3,"s3://crabby-images/d2a6d/d2a6da91fbc681153b96a29103ab7adc4093b9ff" alt=""
CD vs CD
data:image/s3,"s3://crabby-images/1d2ef/1d2ef074bcc1e2e361c2102318d7777f62bef291" alt=""
Continuous Delivery/Deployment
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/ccb68/ccb68fd6023a6fe7f145ccb5e8c21fdbd165529b" alt=""
dev
production
(docker image)
data:image/s3,"s3://crabby-images/f61b3/f61b35dc758bc3e12588513cf75f031f44cecd9f" alt=""
data:image/s3,"s3://crabby-images/29dc2/29dc21e8b1bc17a9bc535aa6483e37d1ff3db7ba" alt=""
Continuous Integration + Continuous Delivery || Continuous Deployment
data:image/s3,"s3://crabby-images/a565d/a565d5ba3f0b411ae6d245ab2ef058991ebe8afb" alt=""
CI/CD pipeline
data:image/s3,"s3://crabby-images/51678/5167849bb7eecdeb06ab2275013053f1b2190b89" alt=""
The most popular tools
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/89df3/89df3c1e94adf313c28760a1c9135699fba7d14b" alt=""
Docker
The possible situation on a new project
data:image/s3,"s3://crabby-images/16bce/16bce576d2fd89b6361d2b3aeabfb53744f4ecfd" alt=""
data:image/s3,"s3://crabby-images/09915/09915315a2ff063f8cef72dfc4ef2390b9794051" alt=""
Requested changes
Use new API for authentication
Login
What should be done to apply changes?
- install all backend related stuff locally (Java, Gradle, Maven, Mongo, PostgreSQL and etc)
- do changes in JavaScript files
- test your changes locally with backend API
- finally - commit changes
data:image/s3,"s3://crabby-images/c7670/c7670739309e425f94aeb9b153cf14117f445219" alt=""
What can happen next
- Changes deployed/published
- QAs do validation, but your change is not working correctly
data:image/s3,"s3://crabby-images/66ad1/66ad16624cd5df33fda4130851f22aa2dec53e7c" alt=""
How it can be done
- Install Docker
- Pull Docker images with latest version of backend API
- Run it locally
- Apply and test your changes
- Profit 🤩
data:image/s3,"s3://crabby-images/47bd0/47bd073d96955b2f30d51ae98e9d990c903be0d5" alt=""
It's how Docker was born
data:image/s3,"s3://crabby-images/9fcfe/9fcfea19ebdbeeade575a69e3651f265d5fd5123" alt=""
data:image/s3,"s3://crabby-images/e1380/e138003ed7f680c812eacb9e51be7340f618f81d" alt=""
Cloud Providers and Containers
data:image/s3,"s3://crabby-images/25c7b/25c7b9eda25bbb72bfe240fec0a1d06ecc199594" alt=""
data:image/s3,"s3://crabby-images/a650f/a650f9634093618e0288b94bbd6de0fc00180d78" alt=""
data:image/s3,"s3://crabby-images/d2901/d29013db3aac246fba8f833741ae2c95ff8486a5" alt=""
data:image/s3,"s3://crabby-images/4d26a/4d26a04081772317b69b98b96d663cbdd545f2bc" alt=""
data:image/s3,"s3://crabby-images/9fcfe/9fcfea19ebdbeeade575a69e3651f265d5fd5123" alt=""
Deploy
Deploy
Deploy
Deploy
About Docker
Docker is an open platform for developing, shipping, and running applications.
- enables you to separate your applications from your infrastructure so you can deliver software quickly
- you can manage your infrastructure in the same ways you manage your applications
- you can shipping, testing, and deploying code quickly
- you can significantly reduce the delay between writing code and running it in production
data:image/s3,"s3://crabby-images/d7425/d7425bc12cf72bcbee9d155e3a9936fc96a1418f" alt=""
Practice time
Our mission
-
Continue working on an online coffee shop “Cold Brew”:
-
Server: MongoDB + Express + NodeJS ( + bonus Docker)
-
UI: React + CSS
-
data:image/s3,"s3://crabby-images/3c7d8/3c7d8b1e8eafb54563413f5fdb1bc94d89e44343" alt=""
Quiz Time
data:image/s3,"s3://crabby-images/7fa72/7fa72e241227fa1f9fa19688e7bd8126fd58ae91" alt=""
Q & A
data:image/s3,"s3://crabby-images/8c52a/8c52a1e12c2c94fd0fed98d9b6a01dc24f2ebd86" alt=""
Homework
-
Continue working in the tutorial6 directory
-
Create frontend part of your app using React + CSS + Formik (optional)
-
Connect your UI (frontend) part with backend
-
Try to use API endpoints from UI
-
Finally - result :)
data:image/s3,"s3://crabby-images/b55a7/b55a719a66abef5fadf9f4b7d278ef5c2fb9d859" alt=""
Helpful souces
data:image/s3,"s3://crabby-images/114c8/114c8e4b9f46a89648d59639b36987a76e2fc02d" alt=""
- My repository with NodeJS tutorials
- official Express documentation
- and of course Stackoverflow
NodeJS Core #7
By Inna Ivashchuk
NodeJS Core #7
- 492