Skip to content

DP-187 Provision Orchestrator's core componenets #4

DP-187 Provision Orchestrator's core componenets

DP-187 Provision Orchestrator's core componenets #4

name: CI/CD Pipeline
on:
push:
branches: [DP-187]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Setup .NET
uses: actions/setup-dotnet@v4
with:
dotnet-version: '8.0.x'
- name: Build .NET Project
run: |
dotnet tool restore
dotnet restore
dotnet build
- name: Build Docker Images
run: make build-docker
- name: Save Docker Images
run: |
docker save -o cdp-images.tar cabinetoffice/cdp-organisation-information-migrations:latest cabinetoffice/cdp-data-sharing:latest cabinetoffice/cdp-entity-verification:latest cabinetoffice/cdp-forms:latest cabinetoffice/cdp-organisation-app:latest cabinetoffice/cdp-organisation:latest cabinetoffice/cdp-person:latest cabinetoffice/cdp-tenant:latest cabinetoffice/cdp-authority:latest
- name: Upload Docker Images as Artifacts
uses: actions/upload-artifact@v4
with:
name: docker-images
path: cdp-images.tar
test:
runs-on: ubuntu-latest
needs: build
env:
CDP_ORGANISATION_APP_PORT: 8888
CDP_TENANT_PORT: 8811
CDP_ORGANISATION_PORT: 8822
CDP_PERSON_PORT: 8833
CDP_FORMS_PORT: 8844
CDP_DATA_SHARING_PORT: 8855
steps:
- uses: actions/checkout@v4
- name: Setup .NET
uses: actions/setup-dotnet@v4
with:
dotnet-version: '8.0.x'
- name: Download Docker Images
uses: actions/download-artifact@v4
with:
name: docker-images
- name: Load Docker Images
run: docker load -i cdp-images.tar
- name: Start services
run: make up
- name: Run Tests
run: |
dotnet test --logger trx --results-directory TestResults
- name: Stop services
run: make down
deploy:
runs-on: ubuntu-latest
needs: test
if: github.ref == 'refs/heads/DP-187' && github.repository_owner == 'cabinetoffice'
steps:
- uses: actions/checkout@v4
- name: Download Docker Images
uses: actions/download-artifact@v4
with:
name: docker-images
- name: Load Docker Images
run: docker load -i cdp-images.tar
- name: Set up AWS CLI
uses: aws-actions/configure-aws-credentials@v4
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: eu-west-2
- name: Login to Amazon ECR
id: login-ecr
uses: aws-actions/amazon-ecr-login@v2
- name: Generate Image Version
id: image_version
run: |
IMAGE_VERSION=$(date +%Y%m%d)-$(git rev-parse --short HEAD)
echo "IMAGE_VERSION=$IMAGE_VERSION" >> $GITHUB_ENV
- name: Tag and Push Docker Images
run: |
for image in cabinetoffice/cdp-organisation-information-migrations cabinetoffice/cdp-data-sharing cabinetoffice/cdp-entity-verification cabinetoffice/cdp-forms cabinetoffice/cdp-organisation-app cabinetoffice/cdp-organisation cabinetoffice/cdp-person cabinetoffice/cdp-tenant cabinetoffice/cdp-authority; do
CLEAN_IMAGE_NAME=$(echo $image | sed 's/^cabinetoffice\///')
docker tag $image:latest ${{ secrets.AWS_ACCOUNT_ID }}.dkr.ecr.eu-west-2.amazonaws.com/$CLEAN_IMAGE_NAME:${{ env.IMAGE_VERSION }}
docker push ${{ secrets.AWS_ACCOUNT_ID }}.dkr.ecr.eu-west-2.amazonaws.com/$CLEAN_IMAGE_NAME:${{ env.IMAGE_VERSION }}
done
- name: Create Git Tag
run: |
git config --global user.name "github-actions"
git config --global user.email "[email protected]"
git tag ${{ env.IMAGE_VERSION }}
git push origin ${{ env.IMAGE_VERSION }}
- name: Store Version in SSM Parameter Store
run: |
aws ssm put-parameter --name "cdp-sirsi-service-version" --value "${{ env.IMAGE_VERSION }}" --type String --overwrite
document:
runs-on: ubuntu-latest
name: Publish documentation
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Build
run: cd docs && make build
- name: Publish
if: github.ref == 'refs/heads/DP-187' && github.repository_owner == 'cabinetoffice'
run: cd docs && make publish-docs-during-cd
- name: Upload Documentation
uses: actions/upload-artifact@v4
with:
name: Documentation
path: docs/build/*