Experimental FIPS support #2191
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Pega Chart Build | |
env: | |
HELM_URL: https://get.helm.sh | |
HELM_TGZ: helm-v3.16.3-linux-amd64.tar.gz | |
YAMLLINT_VERSION: 1.35.1 | |
GO_VERSION: 1.23.4 | |
on: | |
push: | |
tags: | |
- '*' | |
branches-ignore: | |
- gh-pages | |
pull_request: | |
branches: [ master ] | |
workflow_dispatch: | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} | |
cancel-in-progress: true | |
jobs: | |
run-supplemental-validation-job: | |
runs-on: ubuntu-24.04 | |
steps: | |
- name: Check out repository code | |
uses: actions/checkout@v3 | |
- name: Run validate supplementals script | |
run : | | |
sh validate_supplementals.sh | |
run-lint-job: | |
runs-on: ubuntu-24.04 | |
steps: | |
- name: Check out repository code | |
uses: actions/checkout@v3 | |
- name: Install yamllint | |
run: | | |
sudo pip install yamllint=="${{ env.YAMLLINT_VERSION }}" | |
- name: Install Helm | |
run: | | |
sudo rm /usr/local/bin/helm | |
wget -q ${{ env.HELM_URL }}/${{ env.HELM_TGZ }} | |
tar xzf ${{ env.HELM_TGZ }} | |
mv linux-amd64/helm /usr/local/bin/helm | |
- name: run yamllint | |
run: | | |
yamllint -c .yamllint.yml -s $(find . -type f -name "Chart.yaml") | |
yamllint -c .yamllint.yml -s $(find . -type f -name "values*.yaml") | |
- name: update helm dependencies | |
run: | | |
helm dependency update charts/addons | |
helm dependency update charts/backingservices | |
helm dependency update charts/pega | |
- name: run helm lint | |
run: | | |
sh helmlint.sh | |
- name: Install xml lint | |
run: | | |
sudo apt-get update && sudo apt -y install libxml2-utils | |
- name: run xml lint for deploy and installer xml files | |
run: | | |
sh validatexml.sh | |
run-remark-job: | |
runs-on: ubuntu-24.04 | |
steps: | |
- name: Check out repository code | |
uses: actions/checkout@v3 | |
- name: Install node | |
uses: actions/setup-node@v3 | |
with: | |
node-version: lts/* | |
- name: Install npm dependencies | |
run: | | |
npm install -g --save remark-cli to-vfile remark-preset-lint-recommended remark-validate-links remark-lint-no-dead-urls remark-message-control remark-preset-lint-markdown-style-guide remark-lint | |
- name: run remark | |
run: | | |
remark -i .remark_ignore -f -u validate-links . | |
run-go-tests-job: | |
runs-on: ubuntu-24.04 | |
steps: | |
- name: Check out repository code | |
uses: actions/checkout@v3 | |
- name: Install GO | |
uses: actions/setup-go@v3 | |
with: | |
go-version: ${{ env.GO_VERSION }} | |
- run: export PATH=$PATH:/usr/local/go/bin | |
- name: Install Helm | |
run: | | |
sudo rm /usr/local/bin/helm | |
wget -q ${{ env.HELM_URL }}/${{ env.HELM_TGZ }} | |
tar xzf ${{ env.HELM_TGZ }} | |
mv linux-amd64/helm /usr/local/bin/helm | |
- run: helm version | |
- name: Now load the helm dependencies | |
run: | | |
make dependencies | |
- name: Prepare for GO helm unit tests | |
run: | | |
mkdir $GITHUB_WORKSPACE/terratest/bin | |
export GOPATH=$GITHUB_WORKSPACE/terratest | |
export PATH=$PATH:$GITHUB_WORKSPACE/terratest/bin | |
cd terratest/src/test | |
- name: run go tests on pega | |
run: | | |
export GOPATH=$GITHUB_WORKSPACE/terratest | |
export PATH=$PATH:$GITHUB_WORKSPACE/terratest/bin | |
cd terratest/src/test | |
go test ./pega | grep "FAIL" -A 8 || true ; test ${PIPESTATUS[0]} -eq 0 | |
- name: run go tests on addons | |
run: | | |
export GOPATH=$GITHUB_WORKSPACE/terratest | |
export PATH=$PATH:$GITHUB_WORKSPACE/terratest/bin | |
cd terratest/src/test | |
go test ./addons | grep "FAIL" -A 8 || true ; test ${PIPESTATUS[0]} -eq 0 | |
- name: run go tests on backing services | |
run: | | |
export GOPATH=$GITHUB_WORKSPACE/terratest | |
export PATH=$PATH:$GITHUB_WORKSPACE/terratest/bin | |
cd terratest/src/test | |
go test ./backingservices | grep "FAIL" -A 8 || true ; test ${PIPESTATUS[0]} -eq 0 | |
run-deploy-job: | |
runs-on: ubuntu-24.04 | |
needs: [run-lint-job, run-remark-job, run-go-tests-job] | |
if: ( github.ref_type == 'tag' && startsWith(github.ref, 'refs/tags/v') ) && success() | |
steps: | |
- name: Install Helm | |
run: | | |
wget -q ${{ env.HELM_URL }}/${{ env.HELM_TGZ }} | |
tar xzf ${{ env.HELM_TGZ }} | |
ls -l | |
mv linux-amd64/helm /usr/local/bin/helm | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
- name: Now load the helm dependencies | |
run: | | |
make dependencies | |
- name: sync chart version | |
run: | | |
cd $GITHUB_WORKSPACE | |
chmod 777 sync_chart_version.sh | |
./sync_chart_version.sh | |
env: | |
GITHUB_TOKEN: ${{ secrets.GH_ACTIONS_SECRET }} | |
- name: before deploy step 1 | |
run: | | |
cd $GITHUB_WORKSPACE | |
chmod 777 before_deploy.sh | |
./before_deploy.sh | |
- name: before deploy step 2 | |
run: | | |
make examples | |
- name: deploy on github releases | |
uses: softprops/action-gh-release@v1 | |
with: | |
prerelease: false | |
files: | | |
pega-kubernetes-example.tar.gz | |
pega-openshift-example.tar.gz | |
pega-azure-aks-example.tar.gz | |
pega-aws-eks-example.tar.gz | |
pega-google-gke-example.tar.gz | |
pega-pivotal-pks-example.tar.gz | |
token: ${{ secrets.GH_ACTIONS_SECRET }} | |
- name: deploy on github pages | |
run: | | |
cd $GITHUB_WORKSPACE | |
chmod 777 update_gh_pages.sh | |
./update_gh_pages.sh | |
env: | |
GITHUB_TOKEN: ${{ secrets.GH_ACTIONS_SECRET }} |