fix: endpoints vars #25
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: Deploy on release | |
on: | |
release: | |
types: [published] | |
push: | |
branches: | |
- master | |
jobs: | |
unit-tests: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: 20 | |
- uses: actions/checkout@v4 | |
- run: npm --prefix webapp ci | |
- run: npm --prefix webapp test -- --coverage | |
- uses: actions/setup-java@v4 | |
with: | |
distribution: 'temurin' | |
java-version: '17' | |
- run: mvn clean verify | |
working-directory: api | |
env: | |
DATABASE_USER: ${{ secrets.DATABASE_USER }} | |
DATABASE_PASSWORD: ${{ secrets.DATABASE_PASSWORD }} | |
JWT_SECRET: ${{ secrets.JWT_SECRET }} | |
- name: Analyze with SonarCloud | |
uses: sonarsource/sonarcloud-github-action@master | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} | |
e2e-tests: | |
needs: [unit-tests] | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: 20 | |
- run: npm --prefix webapp install | |
- run: npm --prefix webapp run build | |
#- run: npm --prefix webapp run test:e2e TODO: re-enable | |
docker-push-api: | |
runs-on: ubuntu-latest | |
needs: [ e2e-tests ] | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Publish to Registry | |
uses: elgohr/Publish-Docker-Github-Action@v5 | |
env: | |
API_URI: http://${{ secrets.DEPLOY_HOST }}:8080 | |
DATABASE_USER: ${{ secrets.DATABASE_USER }} | |
DATABASE_PASSWORD: ${{ secrets.DATABASE_PASSWORD }} | |
JWT_SECRET: ${{ secrets.JWT_SECRET }} | |
with: | |
name: arquisoft/wiq_en2b/api | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
registry: ghcr.io | |
workdir: api | |
buildargs: API_URI | |
docker-push-webapp: | |
name: Push webapp Docker Image to GitHub Packages | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
packages: write | |
needs: [ e2e-tests ] | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Publish to Registry | |
uses: elgohr/Publish-Docker-Github-Action@v5 | |
env: | |
API_URI: http://${{ secrets.DEPLOY_HOST }}:8000 | |
teamname: wiq_en2b | |
with: | |
name: arquisoft/wiq_en2b/webapp | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
registry: ghcr.io | |
workdir: webapp | |
buildargs: API_URI | |
deploy: | |
name: Deploy over SSH | |
runs-on: ubuntu-latest | |
needs: [docker-push-api, docker-push-webapp] | |
steps: | |
- name: Deploy over SSH | |
uses: fifsky/ssh-action@master | |
env: | |
DATABASE_USER: ${{ secrets.DATABASE_USER }} | |
DATABASE_PASSWORD: ${{ secrets.DATABASE_PASSWORD }} | |
JWT_SECRET: ${{ secrets.JWT_SECRET }} | |
with: | |
host: ${{ secrets.DEPLOY_HOST }} | |
user: ${{ secrets.DEPLOY_USER }} | |
key: ${{ secrets.DEPLOY_KEY }} | |
command: | | |
git clone https://github.com/Arquisoft/wiq_en2b.git | |
git pull | |
cd wiq_en2b | |
echo "DATABASE_USER=${{ secrets.DATABASE_USER }}" >> .env | |
echo "DATABASE_PASSWORD=${{ secrets.DATABASE_PASSWORD }}" >> .env | |
echo "JWT_SECRET=${{ secrets.JWT_SECRET }}" >> .env | |
sudo docker compose down | |
sudo docker compose --profile prod up -d |