CRT makes use of Github Actions and pipline-cli to manage OpenShift deployments. These tools enable a Github Pull Request (PR) based CI/CD pipeline. Github Actions will monitor Github repository for pull requests and start a new build based on that.
This document will not go into the details of how to use Github Actions and pipeline-cli. For documentation on those, you can refer to the following links
- Admin access to OpenShift namespaces, preferably using the standard BC Gov setup of
tools
,dev
,test
andprod
namespaces - Redhat image pull service account
- optional, KeyCloak service account for automatically creating client Valid Redirect URIs for PR based deployments
You will need a Redhat image pull service account before you can continue. Refer to this document on how to create a Redhat image pull service account.
CRT uses two Redhat Docker images and they will be imported as part of the build pipeline. This requires you to have the correct Redhat service account configured.
The Openshift Service Account Access Token is used to give Github Actions access to login Openshift and build and deploy CRT application. In order to create the service account, roles and rolebindings, cd into openshift folder and login Openshift and run the following commands.
oc project 2d982c-tools
oc process -f moti-cicd-service-account.yaml -p NAME=moti-cicd -p PROJECT=2d982c | oc apply -f -
oc process -f moti-cicd-role-binding.yaml -p NAME=moti-cicd -p NAMESPACE=2d982c-tools -p PROJECT=2d982c | oc apply -f -
oc process -f moti-cicd-role-binding.yaml -p NAME=moti-cicd -p NAMESPACE=2d982c-dev -p PROJECT=2d982c | oc apply -f -
oc process -f moti-cicd-role-binding.yaml -p NAME=moti-cicd -p NAMESPACE=2d982c-test -p PROJECT=2d982c | oc apply -f -
oc process -f moti-cicd-role-binding.yaml -p NAME=moti-cicd -p NAMESPACE=2d982c-prod -p PROJECT=2d982c | oc apply -f -
This section will describe the necessary steps required to configure the pipeline to run in your OpenShift environment.
The API Server and Hangfire Server make use of the api-appsettings.yaml file for runtime configurations in OpenShift.
The configmap replaces the default appSettings.json
file from the CRT.Api
project via the s2i run
script when a pod is starting up. So it is imporant it has the correct configurations.
There are a few secret objects that must be created manually in the dev
, test
, and prod
namespaces. These are required for the pods to function properly.
You can use the following templates to create the secret objects. Make sure to replace the parameter variables with actual values encoded to base64.
- database-secrets.yaml
- keycloak-service-account-secrets.yaml
- logdb-postgresql-secrets.yaml
- service-account-secrets.yaml
- sso-secrets.yaml
If you want to let the pipeline automatically update the Valid Redirect URIs for PR based routes then you will need to create the following secret object in the tools
namespace
apiVersion: v1
data:
appClientId: <app-client-id>
clientId: <service-client-id>
clientSecret: <service-client-secret>
host: <dev.ocid.gov.bc.ca>
realmId: <realm-id>
kind: Secret
metadata:
name: keycloak-service-account
type: Opaque
The .pipeline
directory contains the scripts for running pipeline-cli against your OpenShift namespaces. The scripts in the .pipeline
directories in this repository are configured to run against the official CRT OpenShift namespaces (2d982c-
).
You will need to configure the scripts in the .pipeline
directory to work with your OpenShift namespaces.
The pipeline scripts to configure are as follows
- .pipeline/lib/build.js
- .pipeline/lib/clean.js
- .pipeline/lib/config.js
- .pipeline/lib/deploy.js
- .pipeline/lib/utils.js
- .pipeline/lib/keycloak.js
Once Github Actions Workflow is properly configured, it is ready to monitor pull requests.
Every pull request made to your repository will trigger a new build and create a standalone deployment in the dev
namespace. This allows you to test new features independantly of other features.
If configured properly, you can clean up the environments when a pull request is merged or closed using
npm run clean -- --pr=<pr#> ---env=<env>
# Alternative you can use --env=all if you have the transient option configured properly
npm run clean -- --pr=<pr#> --env=all
Use the following steps to manually build and deploy. This assumes you have already logged in.
# Change directory to .pipeline
cd .pipeline
# Installed the required NPM packages
npm install
# Create build for a particular PR on Github
npm run build -- --pr=<pr#>
# Deploy to dev, test, or prod
npm run deploy -- --pr=<pr#> --env=<env>
You can also build from your local source code using the --dev-mode=true
flag. This will upload your local source repository instead of cloning the repository from Github. You may need to delete the client/node_modules
directory before using dev-mode
. The node_modules
directory contains too many files and will often cause the build to fail.
dev-mode
is useful for testing the pipeline without pushing any changes to the remote repository.
npm run build -- --pr=0 --dev-mode=true
You can clean up builds and deployments using
npm run clean -- --pr=<pr#> ---env=<env>
# Alternative you can use --env=all if you have the transient option configured properly
npm run clean -- --pr=<pr#> --env=all