Indy health #439
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: CI | |
on: | |
push: | |
branches: | |
- master | |
pull_request: | |
branches: | |
- "**" | |
jobs: | |
workflow-setup: | |
runs-on: ubuntu-20.04 | |
outputs: | |
CACHE_KEY_API: ${{ steps.mainstep.outputs.CACHE_KEY_API }} | |
CACHE_KEY_WEBAPP: ${{ steps.mainstep.outputs.CACHE_KEY_WEBAPP }} | |
CACHE_KEY_DAEMON: ${{ steps.mainstep.outputs.CACHE_KEY_DAEMON }} | |
CACHE_KEY_DAEMON_UI: ${{ steps.mainstep.outputs.CACHE_KEY_DAEMON_UI }} | |
DOCKER_IMG_NAME_API: ${{ steps.mainstep.outputs.DOCKER_IMG_NAME_API }} | |
DOCKER_IMG_NAME_WEBAPP: ${{ steps.mainstep.outputs.DOCKER_IMG_NAME_WEBAPP }} | |
DOCKER_IMG_NAME_DAEMON: ${{ steps.mainstep.outputs.DOCKER_IMG_NAME_DAEMON }} | |
DOCKER_IMG_NAME_DAEMON_UI: ${{ steps.mainstep.outputs.DOCKER_IMG_NAME_DAEMON_UI }} | |
PUBLISH_VERSION: ${{ steps.mainstep.outputs.PUBLISH_VERSION }} | |
RELEASE: ${{ steps.mainstep.outputs.RELEASE }} | |
PRERELEASE: ${{ steps.mainstep.outputs.PRERELEASE }} | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v1 | |
- name: Set outputs | |
id: mainstep | |
run: | | |
set -x | |
if [[ -z "$GITHUB_HEAD_REF" ]]; then # is set only if pipeline run is triggered as pull request | |
BRANCH_NAME="${GITHUB_REF#refs/heads/}" | |
echo "Setting BRANCH_NAME=$BRANCH_NAME because this pipeline is run as Push" | |
else | |
BRANCH_NAME=$GITHUB_HEAD_REF | |
echo "Setting BRANCH_NAME=$BRANCH_NAME because this pipeline is run as Pull Request" | |
fi | |
BRANCH_NAME=`echo $BRANCH_NAME | sed "s/[^[:alnum:]-]//g" | tr '[:upper:]' '[:lower:]'` # lowercase, only alphanumeric and dash | |
if [[ "${{ github.event_name }}" == "pull_request" ]]; then | |
echo "PR Labels: ${{ toJson(github.event.pull_request.labels.*.name) }}" | |
REPO_HEAD="${{ github.event.pull_request.head.repo.full_name }}" # source repository | |
REPO_BASE="${{ github.event.pull_request.head.base.full_name }}" # target repository | |
echo "This is pull request from $REPO_HEAD to $REPO_BASE" | |
if [[ "$REPO_HEAD" == "${{ github.repository }}" ]]; then | |
echo "This CI run is PR from non-forked repository." | |
IS_FORK="false"; | |
else | |
echo "This is fork." | |
IS_FORK="true"; | |
fi; | |
else | |
echo "Not PR so this is not fork." | |
IS_FORK="false"; | |
fi; | |
REPO_VERSION_MOST_RECENT=$(git describe --tags --always --abbrev=0) | |
REPO_VERSION_DESIRED=`bash ./get-version.sh` | |
echo "Highest released version was: $REPO_VERSION_MOST_RECENT, desired version is: $REPO_VERSION_DESIRED" | |
RELEASE="false" | |
PRERELEASE="false" | |
if [[ "$IS_FORK" == "false" ]]; then | |
if [[ "${{ github.event_name }}" == "pull_request" ]]; then | |
echo "This PR has labels: ${{ toJson(github.event.pull_request.labels) }}" | |
if [[ "${{ contains(github.event.pull_request.labels.*.name, 'pre-release') }}" == "true" ]]; then | |
PRERELEASE="true" | |
fi; | |
elif [[ "${{ github.event_name }}" == "push" ]]; then | |
if [[ "$BRANCH_NAME" == "master" && "$REPO_VERSION_DESIRED" != "$REPO_VERSION_MOST_RECENT" ]]; then | |
PUBLISH_VERSION="$REPO_VERSION_DESIRED" | |
RELEASE="true" | |
echo "This is push to master, and version was bumped from $REPO_VERSION_MOST_RECENT to $REPO_VERSION_DESIRED. Will publish a release of $REPO_VERSION_DESIRED." | |
fi; | |
fi; | |
if [[ -z "$PUBLISH_VERSION" ]]; then | |
PUBLISH_VERSION="$REPO_VERSION_MOST_RECENT-$BRANCH_NAME-${{ github.run_number }}" | |
fi; | |
echo "CI will publish artifacts at version: $PUBLISH_VERSION" | |
else | |
echo "This PR is from fork, nothing will be published because the CI wouldn't be able to access repo secrets to perform publish." | |
PUBLISH_VERSION="" | |
fi; | |
HASH_INDYSCAN_WEBAPP=${{ hashFiles('indyscan-webapp') }} | |
HASH_INDYSCAN_API=${{ hashFiles('indyscan-api') }} | |
HASH_INDYSCAN_API_CLIENT=${{ hashFiles('indyscan-api-client') }} | |
HASH_INDYSCAN_DAEMON=${{ hashFiles('indyscan-daemon') }} | |
HASH_INDYSCAN_DAEMON_API_CLIENT=${{ hashFiles('indyscan-daemon-api-client') }} | |
HASH_INDYSCAN_DAEMON_UI=${{ hashFiles('indyscan-daemon-ui') }} | |
HASH_INDYSCAN_STORAGE=${{ hashFiles('indyscan-storage') }} | |
HASH_INDYSCAN_TXTYPE=${{ hashFiles('indyscan-txtype') }} | |
REBUILD_SEED_API=1 | |
REBUILD_SEED_WEBAPP=1 | |
REBUILD_SEED_DAEMON=1 | |
REBUILD_SEED_DAEMON_UI=2 | |
echo "::set-output name=CACHE_KEY_API::$REBUILD_SEED_API-${HASH_INDYSCAN_API:0:12}-${HASH_INDYSCAN_STORAGE:0:12}-${HASH_INDYSCAN_TXTYPE:0:12}" | |
echo "::set-output name=CACHE_KEY_WEBAPP::$REBUILD_SEED_WEBAPP-${HASH_INDYSCAN_WEBAPP:0:12}-${HASH_INDYSCAN_API_CLIENT:0:12}-${HASH_INDYSCAN_TXTYPE:0:12}" | |
echo "::set-output name=CACHE_KEY_DAEMON::$REBUILD_SEED_DAEMON-${HASH_INDYSCAN_DAEMON:0:12}-${HASH_INDYSCAN_STORAGE:0:12}-${HASH_INDYSCAN_TXTYPE:0:12}" | |
echo "::set-output name=CACHE_KEY_DAEMON_UI::$REBUILD_SEED_DAEMON_UI-${HASH_INDYSCAN_DAEMON_UI:0:12}-${HASH_INDYSCAN_DAEMON_API_CLIENT:0:12}" | |
echo "::set-output name=DOCKER_IMG_NAME_API::indyscan-api" | |
echo "::set-output name=DOCKER_IMG_NAME_WEBAPP::indyscan-webapp" | |
echo "::set-output name=DOCKER_IMG_NAME_DAEMON::indyscan-daemon" | |
echo "::set-output name=DOCKER_IMG_NAME_DAEMON_UI::indyscan-daemon-ui" | |
echo "::set-output name=PUBLISH_VERSION::$PUBLISH_VERSION" | |
echo "::set-output name=RELEASE::$RELEASE" | |
echo "::set-output name=PRERELEASE::$PRERELEASE" | |
lint-and-test-storage: | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v1 | |
- name: Branch name | |
run: echo running on branch ${GITHUB_REF##*/} | |
- name: Install dependencies | |
run: | | |
echo "Installing indyscan-storage" | |
(cd indyscan-storage && npm install) | |
- name: Linter | |
run: | | |
echo "Linting indyscan-storage" | |
(cd indyscan-storage && npm run lint) | |
- name: Unit tests | |
run: | | |
echo "Unit testing indyscan-storage" | |
(cd indyscan-storage && npm run test:unit) | |
lint-and-test-txtype: | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v1 | |
- name: Branch name | |
run: echo running on branch ${GITHUB_REF##*/} | |
- name: Install dependencies | |
run: | | |
echo "Installing indyscan-txtype" | |
(cd indyscan-txtype && npm install) | |
- name: Linter | |
run: | | |
echo "Linting indyscan-txtype" | |
(cd indyscan-txtype && npm run lint) | |
- name: Unit tests | |
run: | | |
echo "Unit testing indyscan-txtype" | |
(cd indyscan-txtype && npm run test:unit) | |
lint-and-test-api-client: | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v1 | |
- name: Branch name | |
run: echo running on branch ${GITHUB_REF##*/} | |
- name: Install dependencies | |
run: | | |
echo "Installing indyscan-api-client" | |
(cd indyscan-api-client && npm install) | |
- name: Linter | |
run: | | |
echo "Linting indyscan-api-client" | |
(cd indyscan-api-client && npm run lint) | |
- name: Unit tests | |
run: | | |
echo "Unit testing indyscan-ap-client" | |
(cd indyscan-api-client && npm run test:unit) | |
lint-and-test-api: | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v1 | |
- name: Branch name | |
run: echo running on branch ${GITHUB_REF##*/} | |
- name: Install dependencies | |
run: | | |
echo "Installing indyscan-storage" | |
(cd indyscan-storage && npm install) | |
echo "Installing indyscan-txtype" | |
(cd indyscan-txtype && npm install) | |
echo "Installing indyscan-api" | |
(cd indyscan-api && npm install) | |
- name: Linter | |
run: | | |
echo "Linting indyscan-api" | |
(cd indyscan-api && npm run lint) | |
- name: Unit tests | |
run: | | |
echo "Unit testing indyscan-api" | |
(cd indyscan-api && npm run test:unit) | |
lint-and-test-webapp: | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v1 | |
- uses: actions/setup-node@v3 | |
with: | |
node-version: 12 | |
- name: Branch name | |
run: echo running on branch ${GITHUB_REF##*/} | |
- name: Install dependencies | |
run: | | |
echo "Installing indyscan-webapp" | |
(cd indyscan-webapp && npm install) | |
# - name: Linter # TEMPORARILY DISABLED: Some problems after latest audit fix, standardjs failing to lint on this project | |
# run: | | |
# echo "Linting indyscan-webapp" | |
# (cd indyscan-webapp && npm run lint) | |
- name: Unit tests | |
run: | | |
echo "Unit testing indyscan-webapp" | |
(cd indyscan-webapp && npm run test:unit) | |
build-docker-api: | |
needs: workflow-setup | |
runs-on: ubuntu-20.04 | |
env: | |
DOCKER_BUILDKIT: 1 | |
CACHE_KEY_API: ${{ needs.workflow-setup.outputs.CACHE_KEY_API }} | |
DOCKER_IMG_NAME_API: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_API }} | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v2 | |
- name: Try load from cache. | |
id: cache-image | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_API }} | |
- name: If NOT found in cache, build and cache image. | |
if: steps.cache-image.outputs.cache-hit != 'true' | |
run: | | |
set -x | |
docker build \ | |
-f indyscan-api/Dockerfile \ | |
-t "$DOCKER_IMG_NAME_API" \ | |
. | |
mkdir -p /tmp/docker | |
docker save "$DOCKER_IMG_NAME_API" > "/tmp/docker/$DOCKER_IMG_NAME_API.rar" | |
- name: Load image from cache | |
run: | | |
docker load < "/tmp/docker/$DOCKER_IMG_NAME_API.rar" | |
- name: Verify image was loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_API" || { echo "Image $DOCKER_IMG_NAME_API was not found!" ; exit 1; } | |
build-docker-webapp: | |
needs: workflow-setup | |
runs-on: ubuntu-20.04 | |
env: | |
DOCKER_BUILDKIT: 1 | |
CACHE_KEY_WEBAPP: ${{ needs.workflow-setup.outputs.CACHE_KEY_WEBAPP }} | |
DOCKER_IMG_NAME_WEBAPP: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_WEBAPP }} | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v2 | |
- name: Try load from cache. | |
id: cache-image | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_WEBAPP }} | |
- name: If NOT found in cache, build and cache image. | |
if: steps.cache-image.outputs.cache-hit != 'true' | |
run: | | |
set -x | |
docker build \ | |
-f indyscan-webapp/Dockerfile \ | |
-t "$DOCKER_IMG_NAME_WEBAPP" \ | |
. | |
mkdir -p /tmp/docker | |
docker save "$DOCKER_IMG_NAME_WEBAPP" > "/tmp/docker/$DOCKER_IMG_NAME_WEBAPP.rar" | |
- name: Load image from cache | |
run: | | |
docker load < "/tmp/docker/$DOCKER_IMG_NAME_WEBAPP.rar" | |
- name: Verify image was loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_WEBAPP" || { echo "Image $DOCKER_IMG_NAME_WEBAPP was not found!" ; exit 1; } | |
build-docker-daemon: | |
needs: [workflow-setup] | |
runs-on: ubuntu-20.04 | |
env: | |
DOCKER_BUILDKIT: 1 | |
CACHE_KEY_DAEMON: ${{ needs.workflow-setup.outputs.CACHE_KEY_DAEMON }} | |
DOCKER_IMG_NAME_DAEMON: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_DAEMON }} | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v2 | |
- name: Try load from cache. | |
id: cache-image | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_DAEMON }} | |
- name: If NOT found in cache, build and cache image. | |
if: steps.cache-image.outputs.cache-hit != 'true' | |
run: | | |
set -x | |
docker build \ | |
-f indyscan-daemon/Dockerfile \ | |
-t "$DOCKER_IMG_NAME_DAEMON" \ | |
. | |
mkdir -p /tmp/docker | |
docker save "$DOCKER_IMG_NAME_DAEMON" > "/tmp/docker/$DOCKER_IMG_NAME_DAEMON.rar" | |
- name: Load image from cache | |
run: | | |
docker load < "/tmp/docker/$DOCKER_IMG_NAME_DAEMON.rar" | |
- name: Verify image was loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_DAEMON" || { echo "Image $DOCKER_IMG_NAME_DAEMON was not found!" ; exit 1; } | |
build-docker-daemon-ui: | |
needs: workflow-setup | |
runs-on: ubuntu-20.04 | |
env: | |
DOCKER_BUILDKIT: 1 | |
CACHE_KEY_DAEMON_UI: ${{ needs.workflow-setup.outputs.CACHE_KEY_DAEMON_UI }} | |
DOCKER_IMG_NAME_DAEMON_UI: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_DAEMON_UI }} | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v2 | |
- name: Try load from cache. | |
id: cache-image | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_DAEMON_UI }} | |
- name: If NOT found in cache, build and cache image. | |
if: steps.cache-image.outputs.cache-hit != 'true' | |
run: | | |
set -x | |
docker build \ | |
-f indyscan-daemon-ui/Dockerfile \ | |
-t "$DOCKER_IMG_NAME_DAEMON_UI" \ | |
. | |
mkdir -p /tmp/docker | |
docker save "$DOCKER_IMG_NAME_DAEMON_UI" > "/tmp/docker/$DOCKER_IMG_NAME_DAEMON_UI.rar" | |
- name: Load image from cache | |
run: | | |
docker load < "/tmp/docker/$DOCKER_IMG_NAME_DAEMON_UI.rar" | |
- name: Verify image was loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_DAEMON_UI" || { echo "Image $DOCKER_IMG_NAME_DAEMON_UI was not found!" ; exit 1; } | |
test-e2e-sovrin: | |
needs: | |
- workflow-setup | |
- build-docker-api | |
- build-docker-webapp | |
- build-docker-daemon | |
- build-docker-daemon-ui | |
runs-on: ubuntu-20.04 | |
env: | |
DOCKER_BUILDKIT: 1 | |
CACHE_KEY_API: ${{ needs.workflow-setup.outputs.CACHE_KEY_API }} | |
DOCKER_IMG_NAME_API: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_API }} | |
CACHE_KEY_WEBAPP: ${{ needs.workflow-setup.outputs.CACHE_KEY_WEBAPP }} | |
DOCKER_IMG_NAME_WEBAPP: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_WEBAPP }} | |
CACHE_KEY_DAEMON: ${{ needs.workflow-setup.outputs.CACHE_KEY_DAEMON }} | |
DOCKER_IMG_NAME_DAEMON: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_DAEMON }} | |
CACHE_KEY_DAEMON_UI: ${{ needs.workflow-setup.outputs.CACHE_KEY_DAEMON_UI }} | |
DOCKER_IMG_NAME_DAEMON_UI: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_DAEMON_UI }} | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v2 | |
- name: Try load from cache. | |
id: load-image-api | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_API }} | |
- name: If NOT found in cache, build and cache image. | |
if: steps.load-image-api.outputs.cache-hit != 'true' | |
run: | | |
echo "Image not found" | |
- name: Load image from cache | |
run: | | |
docker load < /tmp/docker/$DOCKER_IMG_NAME_API.rar | |
- name: Verify image was loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_API" || { echo "Image $DOCKER_IMG_NAME_API was not found!" ; exit 1; } | |
- name: Try load from cache. | |
id: load-image-webapp | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_WEBAPP }} | |
- name: If NOT found in cache, build and cache image. | |
if: steps.load-image-webapp.outputs.cache-hit != 'true' | |
run: | | |
echo "Image not found" | |
- name: Load image from cache | |
run: | | |
docker load < /tmp/docker/$DOCKER_IMG_NAME_WEBAPP.rar | |
- name: Verify image was loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_WEBAPP" || { echo "Image $DOCKER_IMG_NAME_WEBAPP was not found!" ; exit 1; } | |
- name: Try load from cache. | |
id: load-image-daemon | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_DAEMON }} | |
- name: If NOT found in cache, build and cache image. | |
if: steps.load-image-daemon.outputs.cache-hit != 'true' | |
run: | | |
echo "Image not found" | |
- name: Load image from cache | |
run: | | |
docker load < /tmp/docker/$DOCKER_IMG_NAME_DAEMON.rar | |
- name: Verify image was loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_DAEMON" || { echo "Image $DOCKER_IMG_NAME_DAEMON was not found!" ; exit 1; } | |
- name: Try load from cache. | |
id: load-image-daemon-ui | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_DAEMON_UI }} | |
- name: If NOT found in cache, build and cache image. | |
if: steps.load-image-daemon-ui.outputs.cache-hit != 'true' | |
run: | | |
echo "Image not found" | |
- name: Load image from cache | |
run: | | |
docker load < /tmp/docker/$DOCKER_IMG_NAME_DAEMON_UI.rar | |
- name: Verify image was loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_DAEMON_UI" || { echo "Image $DOCKER_IMG_NAME_DAEMON_UI was not found!" ; exit 1; } | |
- name: Run indyscan | |
run: | | |
cd ci/integration-sovrin && make new && sleep 30 | |
- name: Query indyscan-api | |
run: | | |
curl -vv -H "Content-Type: application/json" http://localhost:3708/api/networks/SOVRIN_STAGINGNET/ledgers/domain/txs/5 | |
exit_status=$? | |
if [ $exit_status -eq 1 ]; then | |
exit -1 | |
fi | |
- name: Query indyscan-webapp | |
run: | | |
curl -vv -H "Content-Type: application/json" http://localhost:3707/home/SOVRIN_STAGINGNET | |
exit_status=$? | |
if [ $exit_status -eq 1 ]; then | |
exit -1 | |
fi | |
- name: Collect docker logs on failure | |
if: failure() | |
uses: jwalton/gh-docker-logs@v1 | |
with: | |
dest: './logs' | |
- name: Tar logs | |
if: failure() | |
run: tar cvzf ./logs.tgz ./logs | |
- name: Upload logs to GitHub | |
if: failure() | |
uses: actions/upload-artifact@v2 | |
with: | |
name: logs-test-libvcx-mysql-integration | |
path: ./logs.tgz | |
publish-docker-api: | |
runs-on: ubuntu-20.04 | |
needs: [workflow-setup, build-docker-api] | |
env: | |
CACHE_KEY_API: ${{ needs.workflow-setup.outputs.CACHE_KEY_API }} | |
DOCKER_IMG_NAME_API: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_API }} | |
PUBLISH_VERSION: ${{ needs.workflow-setup.outputs.PUBLISH_VERSION }} | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v2 | |
- name: Load image cache | |
id: load-cached-image | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_API }} | |
- name: If no cached image found | |
if: steps.load-cached-image.outputs.cache-hit != 'true' | |
run: echo "ERROR == Expected to find image from cache $CACHE_KEY_API"; exit -1 | |
- name: Load image from cache | |
run: docker load < /tmp/docker/$DOCKER_IMG_NAME_API.rar | |
- name: Verify libvcx image were loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_API" || { echo "Image $DOCKER_IMG_NAME_API was not found!" ; exit 1; } | |
- name: Docker Login | |
uses: azure/docker-login@v1 | |
with: | |
login-server: docker.pkg.github.com | |
username: $GITHUB_ACTOR | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Publish image | |
run: | | |
if [[ "$PUBLISH_VERSION" ]] | |
then | |
IFS=$':' read -a arr <<< $DOCKER_IMG_NAME_API | |
DOCKER_IMG_NAME_TAGLESS=${arr[0]} | |
GITHUB_REPOSITORY_LOWERCASE=`echo $GITHUB_REPOSITORY | awk '{print tolower($0)}'` | |
REMOTE_DOCKER_IMG_NAME="docker.pkg.github.com/${GITHUB_REPOSITORY_LOWERCASE}/${DOCKER_IMG_NAME_TAGLESS}:${PUBLISH_VERSION}" | |
echo "Publishing image $REMOTE_DOCKER_IMG_NAME" | |
docker tag "$DOCKER_IMG_NAME_API" "$REMOTE_DOCKER_IMG_NAME" | |
docker push "$REMOTE_DOCKER_IMG_NAME" || true | |
else | |
echo "New version was not defined, skipping release." | |
fi | |
publish-docker-webapp: | |
runs-on: ubuntu-20.04 | |
needs: [workflow-setup, build-docker-webapp] | |
env: | |
CACHE_KEY_WEBAPP: ${{ needs.workflow-setup.outputs.CACHE_KEY_WEBAPP }} | |
DOCKER_IMG_NAME_WEBAPP: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_WEBAPP }} | |
PUBLISH_VERSION: ${{ needs.workflow-setup.outputs.PUBLISH_VERSION }} | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v2 | |
- name: Load image cache | |
id: load-cached-image | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_WEBAPP }} | |
- name: If no cached image found | |
if: steps.load-cached-image.outputs.cache-hit != 'true' | |
run: echo "ERROR == Expected to find image from cache $CACHE_KEY_WEBAPP"; exit -1 | |
- name: Load image from cache | |
run: docker load < /tmp/docker/$DOCKER_IMG_NAME_WEBAPP.rar | |
- name: Verify libvcx image were loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_WEBAPP" || { echo "Image $DOCKER_IMG_NAME_WEBAPP was not found!" ; exit 1; } | |
- name: Docker Login | |
uses: azure/docker-login@v1 | |
with: | |
login-server: docker.pkg.github.com | |
username: $GITHUB_ACTOR | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Publish image | |
run: | | |
if [[ "$PUBLISH_VERSION" ]] | |
then | |
IFS=$':' read -a arr <<< $DOCKER_IMG_NAME_WEBAPP | |
DOCKER_IMG_NAME_TAGLESS=${arr[0]} | |
GITHUB_REPOSITORY_LOWERCASE=`echo $GITHUB_REPOSITORY | awk '{print tolower($0)}'` | |
REMOTE_DOCKER_IMG_NAME="docker.pkg.github.com/${GITHUB_REPOSITORY_LOWERCASE}/${DOCKER_IMG_NAME_TAGLESS}:${PUBLISH_VERSION}" | |
echo "Publishing image $REMOTE_DOCKER_IMG_NAME" | |
docker tag "$DOCKER_IMG_NAME_WEBAPP" "$REMOTE_DOCKER_IMG_NAME" | |
docker push "$REMOTE_DOCKER_IMG_NAME" || true | |
else | |
echo "New version was not defined, skipping release." | |
fi | |
publish-docker-daemon: | |
runs-on: ubuntu-20.04 | |
needs: [workflow-setup, build-docker-daemon] | |
env: | |
CACHE_KEY_DAEMON: ${{ needs.workflow-setup.outputs.CACHE_KEY_DAEMON }} | |
DOCKER_IMG_NAME_DAEMON: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_DAEMON }} | |
PUBLISH_VERSION: ${{ needs.workflow-setup.outputs.PUBLISH_VERSION }} | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v2 | |
- name: Load image cache | |
id: load-cached-image | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_DAEMON }} | |
- name: If no cached image found | |
if: steps.load-cached-image.outputs.cache-hit != 'true' | |
run: echo "ERROR == Expected to find image from cache $CACHE_KEY_DAEMON"; exit -1 | |
- name: Load image from cache | |
run: docker load < /tmp/docker/$DOCKER_IMG_NAME_DAEMON.rar | |
- name: Verify libvcx image were loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_DAEMON" || { echo "Image $DOCKER_IMG_NAME_DAEMON was not found!" ; exit 1; } | |
- name: Docker Login | |
uses: azure/docker-login@v1 | |
with: | |
login-server: docker.pkg.github.com | |
username: $GITHUB_ACTOR | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Publish image | |
run: | | |
if [[ "$PUBLISH_VERSION" ]] | |
then | |
IFS=$':' read -a arr <<< $DOCKER_IMG_NAME_DAEMON | |
DOCKER_IMG_NAME_TAGLESS=${arr[0]} | |
GITHUB_REPOSITORY_LOWERCASE=`echo $GITHUB_REPOSITORY | awk '{print tolower($0)}'` | |
REMOTE_DOCKER_IMG_NAME="docker.pkg.github.com/${GITHUB_REPOSITORY_LOWERCASE}/${DOCKER_IMG_NAME_TAGLESS}:${PUBLISH_VERSION}" | |
echo "Publishing image $REMOTE_DOCKER_IMG_NAME" | |
docker tag "$DOCKER_IMG_NAME_DAEMON" "$REMOTE_DOCKER_IMG_NAME" | |
docker push "$REMOTE_DOCKER_IMG_NAME" || true | |
else | |
echo "New version was not defined, skipping release." | |
fi | |
publish-docker-daemon-ui: | |
runs-on: ubuntu-20.04 | |
needs: [workflow-setup, build-docker-daemon-ui] | |
env: | |
CACHE_KEY_DAEMON_UI: ${{ needs.workflow-setup.outputs.CACHE_KEY_DAEMON_UI }} | |
DOCKER_IMG_NAME_DAEMON_UI: ${{ needs.workflow-setup.outputs.DOCKER_IMG_NAME_DAEMON_UI }} | |
PUBLISH_VERSION: ${{ needs.workflow-setup.outputs.PUBLISH_VERSION }} | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v2 | |
- name: Load image cache | |
id: load-cached-image | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/docker | |
key: ${{ env.CACHE_KEY_DAEMON_UI }} | |
- name: If no cached image found | |
if: steps.load-cached-image.outputs.cache-hit != 'true' | |
run: echo "ERROR == Expected to find image from cache $CACHE_KEY_DAEMON_UI"; exit -1 | |
- name: Load image from cache | |
run: docker load < /tmp/docker/$DOCKER_IMG_NAME_DAEMON_UI.rar | |
- name: Verify libvcx image were loaded | |
run: | | |
docker image ls --format "{{.Repository}}:{{.Tag}}" | grep "$DOCKER_IMG_NAME_DAEMON_UI" || { echo "Image $DOCKER_IMG_NAME_DAEMON_UI was not found!" ; exit 1; } | |
- name: Docker Login | |
uses: azure/docker-login@v1 | |
with: | |
login-server: docker.pkg.github.com | |
username: $GITHUB_ACTOR | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Publish image | |
run: | | |
if [[ "$PUBLISH_VERSION" ]] | |
then | |
IFS=$':' read -a arr <<< $DOCKER_IMG_NAME_DAEMON_UI | |
DOCKER_IMG_NAME_TAGLESS=${arr[0]} | |
GITHUB_REPOSITORY_LOWERCASE=`echo $GITHUB_REPOSITORY | awk '{print tolower($0)}'` | |
REMOTE_DOCKER_IMG_NAME="docker.pkg.github.com/${GITHUB_REPOSITORY_LOWERCASE}/${DOCKER_IMG_NAME_TAGLESS}:${PUBLISH_VERSION}" | |
echo "Publishing image $REMOTE_DOCKER_IMG_NAME" | |
docker tag "$DOCKER_IMG_NAME_DAEMON_UI" "$REMOTE_DOCKER_IMG_NAME" | |
docker push "$REMOTE_DOCKER_IMG_NAME" || true | |
else | |
echo "New version was not defined, skipping release." | |
fi | |
make-release: | |
runs-on: ubuntu-20.04 | |
needs: | |
- workflow-setup | |
- lint-and-test-storage | |
- lint-and-test-txtype | |
- lint-and-test-api-client | |
- lint-and-test-api | |
- lint-and-test-webapp | |
- publish-docker-api | |
- publish-docker-webapp | |
- publish-docker-daemon | |
- publish-docker-daemon-ui | |
if: ${{ needs.workflow-setup.outputs.RELEASE == 'true' || needs.workflow-setup.outputs.PRERELEASE == 'true' }} | |
outputs: | |
RELEASE_UPLOAD_URL: ${{ steps.create-release.outputs.upload_url }} | |
steps: | |
- name: Git checkout | |
uses: actions/checkout@v2 | |
- name: Generate changelog | |
uses: heinrichreimer/[email protected] | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
futureRelease: ${{ needs.workflow-setup.outputs.PUBLISH_VERSION }} | |
releaseBranch: master | |
pullRequests: true | |
unreleased: true | |
unreleasedOnly: true | |
issuesWoLabels: true | |
prWoLabels: true | |
stripGeneratorNotice: true | |
stripHeaders: false | |
maxIssues: 50 | |
excludeLabels: duplicate,question,invalid,wontfix,changelog-excluded | |
breakingLabels: backwards-incompatible,breaking | |
deprecatedLabels: deprecated | |
headerLabel: "# Changelog" | |
breakingLabel: '### Breaking changes' | |
enhancementLabel: '### Enhancements' | |
bugsLabel: '### Bug fixes' | |
deprecatedLabel: '### Deprecations' | |
removedLabel: '### Removals' | |
securityLabel: '### Security fixes' | |
issuesLabel: '### Other issues' | |
prLabel: '### Other pull requests' | |
addSections: '{"ci":{"prefix":"### CI changes","labels":["ci"]}}' | |
excludeTagsRegex: '^((([0-9]+)\.([0-9]+)\.([0-9]+)(?:-([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))+)?)$' | |
- name: Create a new release | |
id: create-release | |
uses: actions/create-release@v1 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
tag_name: ${{ needs.workflow-setup.outputs.PUBLISH_VERSION }} | |
release_name: Release ${{ needs.workflow-setup.outputs.PUBLISH_VERSION }} | |
body_path: ./CHANGELOG.md | |
draft: ${{ needs.workflow-setup.outputs.PRERELEASE == 'true' }} | |
prerelease: ${{ needs.workflow-setup.outputs.PRERELEASE == 'true' }} |