Build, test & deploy
data:image/s3,"s3://crabby-images/8060d/8060d60f695be570c5b254d758b9711d1b12ace6" alt=""
data:image/s3,"s3://crabby-images/c2452/c24527d637e13803e04ccddf8c0ecf4257a12e90" alt=""
Angular Raleigh Meetup
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
Hey, Am Udhay (OO-dhy)
data:image/s3,"s3://crabby-images/44feb/44febfcdd5b539edb34748cde847d092f2d9dfaa" alt=""
data:image/s3,"s3://crabby-images/eaa09/eaa0996781cac4ed2cb1b51bc91fec848099c949" alt=""
Agenda
- Intro
- Code, Unit test & Build
- CD/CD - Pipeline
- GitLab
- GCloud - App Engine
- Configure pipeline
- Discussion (Q/A)
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
Build, test & deploy
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
data:image/s3,"s3://crabby-images/8060d/8060d60f695be570c5b254d758b9711d1b12ace6" alt=""
data:image/s3,"s3://crabby-images/a4487/a4487ea685d8f07f9a6bed89e9f0511abb717909" alt=""
data:image/s3,"s3://crabby-images/eaa09/eaa0996781cac4ed2cb1b51bc91fec848099c949" alt=""
Code
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
Clone this repo - https://github.com/askudhay/pounds-to-kg-skeleton
If you want to begin with Skeleton app, and add your own piece of code to create Pounds to Kgs converter logic.
Otherwise, working code here - https://gitlab.com/udhayg/pounds-to-kg
Unit test
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
ng test
Unit test your Angular code by running below command:
Before running that, make sure you have written Unit tests for Components, Pipes, Directives & Services.
ng test --code-coverage
Build
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
// App runs in development mode, that works for debugging.
ng build
// App doesn't run in dev mode
ng build --prod
Build Angular code using below command, that generates artifacts to be deployed to Cloud.
dist/ngpoundtokg - Artifacts generate under this folder.
CI/CD Pipeline
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
Continuous Integration (CI) is a development practice that requires developers to integrate code into a shared repository several times a day.
data:image/s3,"s3://crabby-images/d41ad/d41adba0fc508550d8a08f58aaa6bd1a7417a67f" alt=""
Continuous Delivery (CD) is the natural extension of Continuous Integration: an approach in which teams ensure that every change to the system is releasable, and that we can release any version at the push of a button.
GitLab
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
- Though GitHub is popular in hosting code repositories, it lacked the support for inbuilt pipeline support.
- Recently it introduced GitHub actions to handle cloud native CI/CD operations.
- GitLab is already a leader in providing cloud native continuous integration support.
- Runner execution time - 2000 minutes / month
- Private repositories
Free account
Google Cloud
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
- Though Google Cloud Platform (GCP) is not a leader in Cloud world, their price is cheap and affordable.
- Google App Engine - Used to deploy our static website.
- $300 worth of service free for first year
Free account
GAE - Configuration
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
- Create app.yaml under the project and add below YAML configuration.
runtime: python27
api_version: 1
threadsafe: true
handlers:
- url: /
static_files: dist/ngapp/index.html
upload: dist/ngapp/index.html
- url: /
static_dir: dist/ngapp
skip_files:
- e2e/
- node_modules/
- src/
- ^(.*/)?\..*$
- ^(.*/)?.*\.json$
- ^(.*/)?.*\.md$
- ^(.*/)?.*\.yaml$
- ^LICENSE
gcloud sdk uploads files per this YAML conf.
Pipeline Configuration
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
- Create .gitlab-ci.yml under the project and add below YAML configuration.
stages:
- build_angular
- cloud_deploy
- deploy
cache:
paths:
- ./node_modules
generate_artifact:
image: node:12-alpine
stage: build_angular
script:
- npm install -g @angular/cli --silent
- npm install --silent
- ng build --prod --output-hashing none
artifacts:
paths:
- dist/
gcloud_deploy:
image: google/cloud-sdk:alpine
stage: cloud_deploy
script:
- echo $DEPLOY_KEY_FILE_PRODUCTION > /tmp/$CI_PIPELINE_ID.json
- gcloud auth activate-service-account --key-file /tmp/$CI_PIPELINE_ID.json
- gcloud --project $PROJECT_ID_PRODUCTION app deploy --verbosity=debug
GitLab orchestrates the pipeline execution based on this conf.
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
data:image/s3,"s3://crabby-images/e002b/e002bbdffb4c7859310e36bd3349cf72a35605af" alt=""
- Create project in Google Cloud console.
- Enable App engine by creating an application. Search for GAE in the search bar..
- Create Service account under IAM and add below roles.
data:image/s3,"s3://crabby-images/70322/703229dadb953a9ff2cd7f9cbd0e7cf47fb4b376" alt=""
GCloud Configuration
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
- Create Key and download it.
data:image/s3,"s3://crabby-images/f62b2/f62b258275fad0ed739ca4a9bfea4217cf3abbd6" alt=""
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
data:image/s3,"s3://crabby-images/eb97b/eb97b0bfe175dcb311e69501cc90e3a6a669d406" alt=""
- Add GCloud project ID and JSON key in GitLab > Settings > CI/CD > Variables
DEPLOY_KEY_FILE_PRODUCTION
PROJECT_ID_PRODUCTION
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
data:image/s3,"s3://crabby-images/96c23/96c23d6f510a20729c6c97291323352c6695145e" alt=""
- Goto Storage > Browser and edit bucket permissions for staging.XXXXXX.appspot.com.
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
data:image/s3,"s3://crabby-images/9dce5/9dce5c81c8366056b7992724adbd7c1080391c7f" alt=""
- Add below roles
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
- Search for app engine Admin api and enable it for the project.
data:image/s3,"s3://crabby-images/e1efe/e1efe5aeecca4a0d8e05bfac29bfdf6efbe2372a" alt=""
- Search for cloud build and enable it for the project.
data:image/s3,"s3://crabby-images/d2318/d2318cff7b247ff38e7e99dbaabf923befa1e1e8" alt=""
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
Push the code to GitLab, this will trigger pipeline and deploy the code to Google Cloud - App Engine.
Demo
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""
data:image/s3,"s3://crabby-images/3935d/3935d9b7831526b21a7ceadef85c98faba3f4bdf" alt=""
data:image/s3,"s3://crabby-images/a7af6/a7af67264f57d7f61f501350172e9337eb76ad40" alt=""