Skip to content

Merge pull request #159 from COS301-SE-2024/feat/new-e2e-tests #6

Merge pull request #159 from COS301-SE-2024/feat/new-e2e-tests

Merge pull request #159 from COS301-SE-2024/feat/new-e2e-tests #6

Workflow file for this run

name: Deployment

Check failure on line 1 in .github/workflows/deployment.yaml

View workflow run for this annotation

GitHub Actions / .github/workflows/deployment.yaml

Invalid workflow file

`on.workflow_run` does not reference any workflows. See https://docs.github.com/actions/learn-github-actions/events-that-trigger-workflows#workflow_run for more information
on:
workflow_run:
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout Repo
uses: actions/checkout@v4
- name: Make db env file
uses: SpicyPizza/[email protected]
with:
envkey_POSTGRES_PASSWORD : ${{ secrets.POSTGRES_PASSWORD }}
envkey_POSTGRES_USER : ${{ secrets.POSTGRES_USER }}
envkey_POSTGRES_DB : ${{ secrets.POSTGRES_DB }}
directory: .
file_name: db.env
fail_on_empty: false
- name: Make api env files
uses: SpicyPizza/[email protected]
with:
envkey_DATABASE_URL : ${{ secrets.DATABASE_URL }}
envkey_DATABASE_PORT : ${{ secrets.DATABASE_PORT }}
envkey_DATABASE_NAME : ${{ secrets.DATABASE_NAME }}
envkey_DATABASE_USER : ${{ secrets.DATABASE_USER }}
envkey_DATABASE_PASSWORD : ${{ secrets.DATABASE_PASSWORD }}
envkey_COMPANY_EMAIL : ${{ secrets.COMPANY_EMAIL }}
envkey_COMPANY_AUTH : ${{ secrets.COMPANY_AUTH }}
directory: .
file_name: api.env
fail_on_empty: false
- name: Make fe env files
uses: SpicyPizza/[email protected]
with:
envkey_API_URL : ${{ secrets.API_URL }}
directory: .
file_name: fe.env
fail_on_empty: false
- name: Docker compose build
run: |
cd $GITHUB_WORKSPACE
docker compose build
- name: Make it a tar file
run: |
cd $GITHUB_WORKSPACE
docker save -o frontend.tar dispute-resolution-engine-frontend:latest
docker save -o api.tar api
docker save -o postgres.tar postgres
- name: Install wireguard
run: sudo apt-get install wireguard
- name: Create WG Config
run: |
sed -i -e "s@{{WG_PRIVATEKEY}}@${{ secrets.WG_PRIVATEKEY }}@" $GITHUB_WORKSPACE/tunnel.conf
sed -i -e "s@{{WG_ADDRESS}}@${{ secrets.WG_ADDRESS }}@" $GITHUB_WORKSPACE/tunnel.conf
sed -i -e "s@{{WG_DNS}}@${{ secrets.WG_DNS }}@" $GITHUB_WORKSPACE/tunnel.conf
sed -i -e "s@{{WG_PUBLICKEY}}@${{ secrets.WG_PUBLICKEY }}@" $GITHUB_WORKSPACE/tunnel.conf
sed -i -e "s@{{WG_ALLOWEDIPS}}@${{ secrets.WG_ALLOWEDIPS }}@" $GITHUB_WORKSPACE/tunnel.conf
sed -i -e "s@{{WG_ENDPOINT}}@${{ secrets.WG_ENDPOINT }}@" $GITHUB_WORKSPACE/tunnel.conf
sudo cp $GITHUB_WORKSPACE/tunnel.conf /etc/wireguard/
- name: WG Creating Tunnel
run: |
sudo apt install resolvconf
wg-quick up $GITHUB_WORKSPACE/tunnel.conf
- name: Send through the docker container using scp
uses: appleboy/[email protected]
with:
host: ${{ secrets.SSH_HOST }}
username: ${{ secrets.SSH_USERNAME }}
password: ${{ secrets.SSH_PASSWORD }}
port: ${{ secrets.SSH_PORT }}
source: "api.tar,frontend.tar,postgres.tar,docker-compose.yaml"
target: ./
- name: Spin up docker image
uses: appleboy/[email protected]
with:
host: ${{ secrets.SSH_HOST }}
username: ${{ secrets.SSH_USERNAME }}
password: ${{ secrets.SSH_PASSWORD }}
port: ${{ secrets.SSH_PORT }}
script: |
docker load -i frontend.tar
docker load -i api.tar
docker load -i postgres.tar
docker-compose up -d
cypress-test:
container:
image: cypress/included
needs: deploy
runs-on: ubuntu-latest
steps:
- name: Checkout Repo
uses: actions/checkout@v4
- name: Cypress run
uses: cypress-io/github-action@v2
with:
wait-on: 'http://capstone-dre.dns.net.za'
wait-on-timeout: 300
- name: Upload coverage reports to Codecov
uses: codecov/[email protected]
with:
token: ${{ secrets.CODECOV_TOKEN }}