Skip to content

Commit

Permalink
feat(github-workflows): add ci for pr build check and for release bui…
Browse files Browse the repository at this point in the history
…ld and deployment

Signed-off-by: Charles Madjeri <[email protected]>
  • Loading branch information
Charles Madjeri committed Dec 3, 2024
1 parent 4963872 commit 6b6a5b4
Show file tree
Hide file tree
Showing 5 changed files with 161 additions and 1 deletion.
2 changes: 1 addition & 1 deletion .github/workflows/deploy-documentation.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
name: deploy-documentation

on: [push, pull_request, workflow_dispatch]
on: [push, workflow_dispatch]

permissions:
contents: write
Expand Down
63 changes: 63 additions & 0 deletions .github/workflows/pr-check.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
name: PR Check Pipeline

on:
pull_request:
branches: [ master, dev ]

jobs:
build:
runs-on: ubuntu-latest
environment: docker-build

steps:
- uses: actions/checkout@v4

- name: Create env files
run: |
# Create mobile env file
cat << EOF > client_mobile/.env.mobile
VITE_PORT=${{ secrets.VITE_PORT }}
VITE_ENDPOINT=${{ secrets.VITE_ENDPOINT }}
VITE_GOOGLE_CLIENT_ID=${{ secrets.VITE_GOOGLE_CLIENT_ID }}
VITE_GOOGLE_CLIENT_SECRET=${{ secrets.VITE_GOOGLE_CLIENT_SECRET }}
VITE_MICROSOFT_CLIENT_ID=${{ secrets.VITE_MICROSOFT_CLIENT_ID }}
VITE_LINKEDIN_CLIENT_ID=${{ secrets.VITE_LINKEDIN_CLIENT_ID }}
VITE_LINKEDIN_CLIENT_SECRET=${{ secrets.VITE_LINKEDIN_CLIENT_SECRET }}
VITE_SPOTIFY_CLIENT_ID=${{ secrets.VITE_SPOTIFY_CLIENT_ID }}
VITE_SPOTIFY_CLIENT_SECRET=${{ secrets.VITE_SPOTIFY_CLIENT_SECRET }}
API_URL=${{ secrets.API_URL }}
WEB_CLIENT_URL=${{ secrets.WEB_CLIENT_URL }}
MOBILE_CLIENT_URL=${{ secrets.MOBILE_CLIENT_URL }}
GITHUB_CLIENT_ID=${{ secrets.GH_CLIENT_ID }}
GITHUB_CLIENT_SECRET=${{ secrets.GH_CLIENT_SECRET }}
EOF
# Create web env file
cat << EOF > client_web/.env.local
VITE_PORT=${{ secrets.VITE_PORT }}
VITE_ENDPOINT=${{ secrets.VITE_ENDPOINT }}
VITE_GOOGLE_CLIENT_ID=${{ secrets.VITE_GOOGLE_CLIENT_ID }}
VITE_GOOGLE_CLIENT_SECRET=${{ secrets.VITE_GOOGLE_CLIENT_SECRET }}
VITE_MICROSOFT_CLIENT_ID=${{ secrets.VITE_MICROSOFT_CLIENT_ID }}
VITE_LINKEDIN_CLIENT_ID=${{ secrets.VITE_LINKEDIN_CLIENT_ID }}
VITE_LINKEDIN_CLIENT_SECRET=${{ secrets.VITE_LINKEDIN_CLIENT_SECRET }}
VITE_SPOTIFY_CLIENT_ID=${{ secrets.VITE_SPOTIFY_CLIENT_ID }}
VITE_SPOTIFY_CLIENT_SECRET=${{ secrets.VITE_SPOTIFY_CLIENT_SECRET }}
API_URL=${{ secrets.API_URL }}
WEB_CLIENT_URL=${{ secrets.WEB_CLIENT_URL }}
MOBILE_CLIENT_URL=${{ secrets.MOBILE_CLIENT_URL }}
GITHUB_CLIENT_ID=${{ secrets.GH_CLIENT_ID }}
GITHUB_CLIENT_SECRET=${{ secrets.GH_CLIENT_SECRET }}
EOF
# Create root env file if needed
cat << EOF > .env
VITE_PORT=${{ secrets.VITE_PORT }}
EOF
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3

- name: Build Docker images
run: |
docker compose build
93 changes: 93 additions & 0 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
name: Create Release

on:
push:
branches: [ master, cma/feat-ci-build-docker ]

jobs:
release:
runs-on: ubuntu-latest
environment: docker-build

steps:
- uses: actions/checkout@v4

- name: Create env files
run: |
# Create mobile env file
cat << EOF > client_mobile/.env.mobile
VITE_PORT=${{ secrets.VITE_PORT }}
VITE_ENDPOINT=${{ secrets.VITE_ENDPOINT }}
VITE_GOOGLE_CLIENT_ID=${{ secrets.VITE_GOOGLE_CLIENT_ID }}
VITE_GOOGLE_CLIENT_SECRET=${{ secrets.VITE_GOOGLE_CLIENT_SECRET }}
VITE_MICROSOFT_CLIENT_ID=${{ secrets.VITE_MICROSOFT_CLIENT_ID }}
VITE_LINKEDIN_CLIENT_ID=${{ secrets.VITE_LINKEDIN_CLIENT_ID }}
VITE_LINKEDIN_CLIENT_SECRET=${{ secrets.VITE_LINKEDIN_CLIENT_SECRET }}
VITE_SPOTIFY_CLIENT_ID=${{ secrets.VITE_SPOTIFY_CLIENT_ID }}
VITE_SPOTIFY_CLIENT_SECRET=${{ secrets.VITE_SPOTIFY_CLIENT_SECRET }}
API_URL=${{ secrets.API_URL }}
WEB_CLIENT_URL=${{ secrets.WEB_CLIENT_URL }}
MOBILE_CLIENT_URL=${{ secrets.MOBILE_CLIENT_URL }}
GITHUB_CLIENT_ID=${{ secrets.GH_CLIENT_ID }}
GITHUB_CLIENT_SECRET=${{ secrets.GH_CLIENT_SECRET }}
EOF
# Create web env file
cat << EOF > client_web/.env.local
VITE_PORT=${{ secrets.VITE_PORT }}
VITE_ENDPOINT=${{ secrets.VITE_ENDPOINT }}
VITE_GOOGLE_CLIENT_ID=${{ secrets.VITE_GOOGLE_CLIENT_ID }}
VITE_GOOGLE_CLIENT_SECRET=${{ secrets.VITE_GOOGLE_CLIENT_SECRET }}
VITE_MICROSOFT_CLIENT_ID=${{ secrets.VITE_MICROSOFT_CLIENT_ID }}
VITE_LINKEDIN_CLIENT_ID=${{ secrets.VITE_LINKEDIN_CLIENT_ID }}
VITE_LINKEDIN_CLIENT_SECRET=${{ secrets.VITE_LINKEDIN_CLIENT_SECRET }}
VITE_SPOTIFY_CLIENT_ID=${{ secrets.VITE_SPOTIFY_CLIENT_ID }}
VITE_SPOTIFY_CLIENT_SECRET=${{ secrets.VITE_SPOTIFY_CLIENT_SECRET }}
API_URL=${{ secrets.API_URL }}
WEB_CLIENT_URL=${{ secrets.WEB_CLIENT_URL }}
MOBILE_CLIENT_URL=${{ secrets.MOBILE_CLIENT_URL }}
GITHUB_CLIENT_ID=${{ secrets.GH_CLIENT_ID }}
GITHUB_CLIENT_SECRET=${{ secrets.GH_CLIENT_SECRET }}
EOF
# Create root env file if needed
cat << EOF > .env
VITE_PORT=${{ secrets.VITE_PORT }}
EOF
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3

- name: Build Docker images
run: |
docker compose up --build -d
- name: List Docker images
run: |
docker ps
- name: Extract APK
run: |
mkdir -p artifacts
docker cp area-client-web:/usr/share/nginx/html/mobile_builds/client.apk ./artifacts/
- name: Create Release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: v${{ github.run_number }}
release_name: Release v${{ github.run_number }}
draft: false
prerelease: false

- name: Upload Release APK
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./artifacts/client.apk
asset_name: area-mobile-v${{ github.run_number }}.apk
asset_content_type: application/vnd.android.package-archive
1 change: 1 addition & 0 deletions client_mobile/.gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ migrate_working_dir/
.pub-cache/
.pub/
/build/
pubspec.lock

# Symbolication related
app.*.symbols
Expand Down
3 changes: 3 additions & 0 deletions client_web/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,9 @@ FROM node:latest AS builder

WORKDIR /app

COPY --from=cert-builder /localhost.pem /app/localhost.pem
COPY --from=cert-builder /localhost-key.pem /app/localhost-key.pem

ARG VITE_PORT
ARG VITE_ENDPOINT
ARG VITE_GOOGLE_CLIENT_ID
Expand Down

0 comments on commit 6b6a5b4

Please sign in to comment.