Skip to content

Merge pull request #4236 from hove-io/add_newrelic_event_on_free_acce… #203

Merge pull request #4236 from hove-io/add_newrelic_event_on_free_acce…

Merge pull request #4236 from hove-io/add_newrelic_event_on_free_acce… #203

name: Build Navitia Dockers (Dev)
on:
push:
branches:
- dev
env:
jessie_version: debian8
bullseye_version: debian11
front_jessie_navitia_components: 'tyr-web instances-configurator'
backend_jessie_navitia_components: 'kraken tyr-beat tyr-worker mock-kraken eitri'
SBX_ECR_REGISTRY_BACKEND: "110444322584.dkr.ecr.eu-west-1.amazonaws.com"
SBX_ECR_REGISTRY_FRONT: "051314639660.dkr.ecr.eu-west-1.amazonaws.com"
TAG: 'dev'
jobs:
front_bullseye_builder:
runs-on: [self-hosted, corefront, sandbox]
name: Front Bullseye builder (Dev)
steps:
- name: force chown to avoid errors
run: sudo chown -R $USER:$USER .
- name: Git config
run: git config --global --add safe.directory /__w/navitia/navitia
- name: Install dependencies
run: |
sudo apt update && sudo apt install -y httpie
- name: Generate github private access token
id: ci-core-app-token
uses: getsentry/[email protected]
with:
app_id: ${{ secrets.CI_CORE_APP_ID }}
private_key: ${{ secrets.CI_CORE_APP_PEM }}
- name: Checkout
uses: actions/checkout@v3
with:
submodules: recursive
token: ${{ steps.ci-core-app-token.outputs.token }}
# we need entire history for tags
fetch-depth: 0
# - name: Restore ccache
# uses: hendrikmuhs/[email protected]
# with:
# key: build_dockers
# max-size: 2000M
- name: Login to Amazon ECR SBX
uses: aws-actions/amazon-ecr-login@v1
env:
AWS_REGION: eu-west-1
- name: Login to Amazon ECR Shared
uses: aws-actions/amazon-ecr-login@v1
env:
AWS_REGION: eu-west-1
with:
registries: "162230498103"
- name: Create builder docker
run: |
docker build -f docker/${{env.bullseye_version}}/Dockerfile-builder -t navitia/builder .
- name: Build navitia
run: |
docker run -v `pwd`:/navitia/navitia/ navitia/builder
- name: Create navitia images
run: |
echo "********* Building Jormungandr ***************"
docker build -t ${SBX_ECR_REGISTRY_FRONT}/jormungandr:no_config_${TAG} -f docker/${{env.bullseye_version}}/Dockerfile-jormungandr .
- name: Push images on SBX ECR
run: |
echo "********* Push Jormungandr ***************"
docker push ${SBX_ECR_REGISTRY_FRONT}/jormungandr:no_config_${TAG}
- name: failure notification
if: failure()
run: |
echo '{"text":":warning: Github Actions: workflow dockers_builder_dev Job front_bullseye_builder is failed !"}' | http --json POST ${{secrets.SLACK_NAVITIA_TEAM_URL}}
- name: clean up workspace
if: ${{ always() }}
run: |
# some files are created by a docker container
sudo chown -R $USER:$USER .
rm -rf ./*
rm -rf ./.??*
front_jessie_builder:
runs-on: [self-hosted, corefront, sandbox]
name: Front Jessie builder (Dev)
steps:
- name: force chown to avoid errors
run: sudo chown -R $USER:$USER .
- name: Git config
run: git config --global --add safe.directory /__w/navitia/navitia
- name: Install dependencies
run: |
sudo apt update && sudo apt install -y httpie
- name: Generate github private access token
id: ci-core-app-token
uses: getsentry/[email protected]
with:
app_id: ${{ secrets.CI_CORE_APP_ID }}
private_key: ${{ secrets.CI_CORE_APP_PEM }}
- name: Checkout
uses: actions/checkout@v3
with:
submodules: recursive
token: ${{ steps.ci-core-app-token.outputs.token }}
# we need entire history for tags
fetch-depth: 0
# - name: Restore ccache
# uses: hendrikmuhs/[email protected]
# with:
# key: build_dockers
# max-size: 2000M
- name: Login to Amazon ECR SBX
uses: aws-actions/amazon-ecr-login@v1
env:
AWS_REGION: eu-west-1
- name: Login to Amazon ECR Shared
uses: aws-actions/amazon-ecr-login@v1
env:
AWS_REGION: eu-west-1
with:
registries: "162230498103"
- name: Create master docker
run: |
docker build -f docker/${{env.jessie_version}}/Dockerfile-master -t navitia/master .
docker build -f docker/${{env.jessie_version}}/Dockerfile-builder -t navitia/builder .
- name: Build packages in master docker
# Will build navitia-*.deb packages in current folder
run: docker run -v `pwd`:/build/navitia/ navitia/builder
- name: Create navitia images
run: |
for component in ${{env.front_jessie_navitia_components}}; do
echo "********* Building $component ***************"
docker build -t ${SBX_ECR_REGISTRY_FRONT}/$component:${TAG} -f docker/${{env.jessie_version}}/Dockerfile-${component} .
done
- name: Push images on SBX ECR
run: |
for component in ${{env.front_jessie_navitia_components}}; do
echo "********* Building $component ***************"
docker push ${SBX_ECR_REGISTRY_FRONT}/$component:${TAG}
done
- name: failure notification
if: failure()
run: |
echo '{"text":":warning: Github Actions: workflow dockers_builder_dev Job front_jessie_builder is failed !"}' | http --json POST ${{secrets.SLACK_NAVITIA_TEAM_URL}}
- name: clean up workspace
if: ${{ always() }}
run: |
# some files are created by a docker container
sudo chown -R $USER:$USER .
rm -rf ./*
rm -rf ./.??*
backend_jessie_builder:
runs-on: [self-hosted, kraken, sandbox]
name: Backend Jessie builder (Dev)
steps:
- name: force chown to avoid errors
run: sudo chown -R $USER:$USER .
- name: Git config
run: git config --global --add safe.directory /__w/navitia/navitia
- name: Install dependencies
run: |
sudo apt update && sudo apt install -y zip httpie curl python3 python3-pip
- name: Generate github private access token
id: ci-core-app-token
uses: getsentry/[email protected]
with:
app_id: ${{ secrets.CI_CORE_APP_ID }}
private_key: ${{ secrets.CI_CORE_APP_PEM }}
- name: Checkout
uses: actions/checkout@v3
with:
submodules: recursive
token: ${{ steps.ci-core-app-token.outputs.token }}
# we need entire history for tags
fetch-depth: 0
- name: Checkout core_team_ci_tools
uses: actions/checkout@v3
with:
repository : 'hove-io/core_team_ci_tools'
path: core_team_ci_tools
token: ${{ steps.ci-core-app-token.outputs.token }}
- name: Setup core_team_ci_tools python environment
run: |
pip install -r core_team_ci_tools/github_artifacts/requirements.txt --user
- name: Download mimirsbrunn package
run: |
mimirsbrunn_package="debian-package-master.zip"
python3 core_team_ci_tools/github_artifacts/github_artifacts.py \
-o hove-io \
-r mimirsbrunn \
-t ${{ steps.ci-core-app-token.outputs.token }} \
-w main7.yml \
-a debian-package-master.zip \
--output-dir .
unzip -qo $mimirsbrunn_package
rm -f $mimirsbrunn_package
- name: Download cosmogony2cities package
run: |
cosmogony2cities_package="package-${{env.jessie_version}}.zip"
python3 core_team_ci_tools/github_artifacts/github_artifacts.py \
-o hove-io \
-r cosmogony2cities \
-t ${{ steps.ci-core-app-token.outputs.token }} \
-w build_package.yml \
-a $cosmogony2cities_package \
--output-dir .
unzip -qo $cosmogony2cities_package
rm -f $cosmogony2cities_package
- name: Download mimir-config package
run: |
conf_mimir_package="debian-package-release.zip"
python3 core_team_ci_tools/github_artifacts/github_artifacts.py \
-o hove-io \
-r mimirsbrunn-config \
-t ${{ steps.ci-core-app-token.outputs.token }} \
-w release.yml \
-a $conf_mimir_package \
-b main \
--skip-check-artifacts-size \
--output-dir .
unzip -qo $conf_mimir_package
rm -f $conf_mimir_package
# - name: Restore ccache
# uses: hendrikmuhs/[email protected]
# with:
# key: build_dockers
# max-size: 2000M
- name: Login to Amazon ECR SBX
uses: aws-actions/amazon-ecr-login@v1
env:
AWS_REGION: eu-west-1
- name: Login to Amazon ECR Shared
uses: aws-actions/amazon-ecr-login@v1
env:
AWS_REGION: eu-west-1
with:
registries: "162230498103"
- name: Create master docker
run: |
docker build -f docker/${{env.jessie_version}}/Dockerfile-master -t navitia/master .
docker build -f docker/${{env.jessie_version}}/Dockerfile-builder -t navitia/builder .
- name: Build packages in master docker
# Will build navitia-*.deb packages in current folder
run: docker run -v `pwd`:/build/navitia/ navitia/builder
- name: Create navitia images
run: |
for component in ${{env.backend_jessie_navitia_components}}; do
echo "********* Building $component ***************"
docker build -t ${SBX_ECR_REGISTRY_BACKEND}/$component:${TAG} --build-arg GITHUB_TOKEN=${{ steps.ci-core-app-token.outputs.token }} -f docker/${{env.jessie_version}}/Dockerfile-${component} .
done
- name: Push images on SBX ECR
run: |
for component in ${{env.backend_jessie_navitia_components}}; do
echo "********* Building $component ***************"
docker push ${SBX_ECR_REGISTRY_BACKEND}/$component:${TAG}
done
- name: failure notification
if: failure()
run: |
echo '{"text":":warning: Github Actions: workflow dockers_builder_dev Job backend_jessie_builder is failed !"}' | http --json POST ${{secrets.SLACK_NAVITIA_TEAM_URL}}
- name: clean up workspace
if: ${{ always() }}
run: |
# some files are created by a docker container
sudo chown -R $USER:$USER .
rm -rf ./*
rm -rf ./.??*
publish_aws:
runs-on: [self-hosted, corefront, sandbox]
name: Aws Dispatch (Dev)
needs: [front_jessie_builder, front_bullseye_builder, backend_jessie_builder]
steps:
- name: Install dependencies
run: |
sudo apt update && sudo apt install -y httpie
- name: Generate token for aws images
id: app-token
uses: getsentry/[email protected]
with:
app_id: ${{ secrets.GA_OS_WORKFLOW_TRIGGER_APP_ID }}
private_key: ${{ secrets.GA_OS_WORKFLOW_TRIGGER_APP_PEM }}
- name: Aws Dispatch Frontend
uses: peter-evans/repository-dispatch@v2
with:
token: ${{ steps.app-token.outputs.token }}
repository: hove-io/corefront-aws-assets
event-type: build-trigger
client-payload: '{"branch": "dev", "tag": "dev"}'
- name: failure notification
if: failure()
run: |
echo '{"text":":warning: Github Actions: dockers_builder_dev the job publish_aws is failed !"}' | http --json POST ${{secrets.SLACK_NAVITIA_TEAM_URL}}
run_artemis:
runs-on: [self-hosted, corefront, sandbox]
needs: [front_jessie_builder, front_bullseye_builder, backend_jessie_builder, publish_aws]
name: Run artemis Dispatch (Dev)
steps:
- name: Install dependencies
run: |
sudo apt update && sudo apt install -y httpie
- name: Generate github private access token
id: ci-core-app-token
uses: getsentry/[email protected]
with:
app_id: ${{ secrets.CI_CORE_APP_ID }}
private_key: ${{ secrets.CI_CORE_APP_PEM }}
- name: Run artemis on push to dev
uses: peter-evans/repository-dispatch@v2
with:
token: ${{ steps.ci-core-app-token.outputs.token }}
repository: hove-io/artemis
event-type: run_artemis_ng
- name: failure notification
if: failure()
run: |
echo '{"text":":warning: Github Actions: workflow dockers_builder_dev Job run_artemis is failed !"}' | http --json POST ${{secrets.SLACK_NAVITIA_TEAM_URL}}