Skip to content

Temp test.properties file #9

Temp test.properties file

Temp test.properties file #9

Workflow file for this run

name: CI/CD
on:
push:
branches:
- test-ci-cd-workflow
pull_request:
branches:
- main
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Set up JDK 17
uses: actions/setup-java@v2
with:
java-version: '17'
distribution: 'adopt'
- name: Install Maven
run: sudo apt-get install -y maven
- name: Install Chromedriver
run: sudo apt-get install -y chromium-chromedriver
- name: Wait for PostgreSQL to be ready
run: |
until pg_isready -h ${{ secrets.DB_HOST }} -p ${{ secrets.DB_PORT }} -U ${{ secrets.DATABASE_USERNAME }}; do echo waiting for postgres; sleep 2; done
- name: Retrieve secrets from 1Password
id: load-secrets
uses: 1Password/load-secrets-action@v1
with:
export-env: false
env:
OP_SERVICE_ACCOUNT_TOKEN: ${{ secrets.OP_SERVICE_ACCOUNT_TOKEN }}
- name: Set environment variables
run: |
echo "OP_EMAIL=$(op read op://Shared/OP_EMAIL)" >> $GITHUB_ENV
echo "OP_SECRET_KEY=$(op read op://Shared/OP_SECRET_KEY)" >> $GITHUB_ENV
echo "DB_HOST=$(op read op://Shared/DB_HOST)" >> $GITHUB_ENV
echo "DATABASE_USERNAME=$(op read op://Shared/DATABASE_USERNAME)" >> $GITHUB_ENV
echo "DATABASE_PASSWORD=$(op read op://Shared/DATABASE_PASSWORD)" >> $GITHUB_ENV
- name: Authenticate with 1Password
run: |
eval $(op account add --address https://team-deloittedigital.1password.com --email $OP_EMAIL --secret-key $OP_SECRET_KEY --signin)
eval $(op signin my)
- name: Build with Maven
env:
DB_HOST: ${{ env.DB_HOST }}
DB_PORT: ${{ secrets.DB_PORT }}
DB_NAME: ${{ secrets.DB_NAME }}
DB_USER: ${{ env.DATABASE_USERNAME }}
DB_PASSWORD: ${{ env.DATABASE_PASSWORD }}
DATABASE_URL: ${{ secrets.DATABASE_URL }}
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
AWS_REGION: ${{ secrets.AWS_REGION }}
AWS_S3_BUCKET_NAME: ${{ secrets.AWS_S3_BUCKET_NAME }}
run: mvn clean package -DskipTests
- name: Run tests
env:
DB_HOST: ${{ env.DB_HOST }}
DB_PORT: ${{ secrets.DB_PORT }}
DB_NAME: ${{ secrets.DB_NAME }}
DB_USER: ${{ env.DATABASE_USERNAME }}
DB_PASSWORD: ${{ env.DATABASE_PASSWORD }}
DATABASE_URL: ${{ secrets.DATABASE_URL }}
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
AWS_REGION: ${{ secrets.AWS_REGION }}
AWS_S3_BUCKET_NAME: ${{ secrets.AWS_S3_BUCKET_NAME }}
run: mvn test
- name: Build Docker image
run: docker build -t mhk1/acebook_penguins:latest .
- name: Login to Docker Hub
run: echo "${{ secrets.DOCKERHUB_PASSWORD }}" | docker login -u "${{ secrets.DOCKERHUB_USERNAME }}" --password-stdin
- name: Push Docker image
run: docker push mhk1/acebook_penguins:latest