Skip to content

Enhance JPA config page (#144) #586

Enhance JPA config page (#144)

Enhance JPA config page (#144) #586

Workflow file for this run

# Copyright Jiaqi Liu
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
---
name: Template CI/CD
"on":
pull_request:
push:
branches:
- master
env:
JDK_VERSION: 17
JDK_DISTRIBUTION: 'adopt'
USER: QubitPi
EMAIL: jack20220723@gmail.com
jobs:
mk-yml-style-check:
uses: QubitPi/hashicorp-aws/.github/workflows/yml-and-md-style-checks.yml@master
tests:
name: Unit & Integration Tests
needs: mk-yml-style-check
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Test environment setup
uses: ./.github/actions/ci-setup
- name: Set up Docker for Integration Tests
uses: docker-practice/actions-setup-docker@master
- name: Run unit & integration tests
run: mvn -B clean verify
documentation:
name: Test & Release Documentation (including Javadoc)
needs: tests
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 18
- name: Test environment setup
uses: ./.github/actions/ci-setup
- name: Install dependencies
working-directory: docs
run: yarn
- name: Build documentations
working-directory: docs
run: yarn build
- name: Generate Javadoc
run: mvn -B clean javadoc:javadoc
- name: Move Javadoc into documentation directory
if: github.ref == 'refs/heads/master'
run: mv target/site/apidocs/ docs/build/apidocs/
- name: Deploy documentation (including Javadoc) to GitHub Pages
if: github.ref == 'refs/heads/master'
uses: peaceiris/actions-gh-pages@v3
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_dir: docs/build
enable_jekyll: false
user_name: ${{ env.USER }}
user_email: ${{ env.EMAIL }}
docker-image:
name: Build Test & Release Development Docker Image
needs: tests
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Test environment setup
uses: ./.github/actions/ci-setup
- name: Build App WAR file so that Docker can pickup during image build
run: mvn clean package
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Test image build
uses: docker/build-push-action@v3
with:
context: .
push: false
- name: Login to DockerHub
if: github.ref == 'refs/heads/master'
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Push image to DockerHub
if: github.ref == 'refs/heads/master'
uses: docker/build-push-action@v3
with:
context: .
push: true
tags: ${{ secrets.DOCKERHUB_USERNAME }}/jersey-webservice-template:latest
hashicorp:
name: Generated Webservice WAR in GitHub Action, and Publish Template AMI Image and Deploy it to EC2 through HashiCorp
if: ${{ github.event.repository.name != 'jersey-webservice-template' }} # change this to "if: github.ref == 'refs/heads/master'" in fork
needs: tests
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Deployment environment setup
uses: QubitPi/hashicorp-aws/hashicorp/webservice/auxiliary/github/actions/cd-setup@master
with:
aws-ws-pkrvars-hcl: ${{ secrets.AWS_WS_PKRVARS_HCL }}
ssl-certificate: ${{ secrets.SSL_CERTIFICATE }}
ssl-certificate-key: ${{ secrets.SSL_CERTIFICATE_KEY }}
nginx-config-file: ${{ secrets.NGINX_CONFIG_FILE }}
filebeat-config-file: ${{ secrets.FILEBEAT_CONFIG_FILE }}
aws-ws-tfvars: ${{ secrets.AWS_WS_TFVARS }}
- name: Load webservice properties files
run: echo '${{ secrets.OAUTH_PROPERTIES }}' > src/main/resources/oauth.properties
- name: Generate webservice WAR file
run: mvn -B clean package
- name: Move WAR file to a location for HashiCorp deployment to pickup
run: mv target/astraios-1.0-SNAPSHOT.war ../hashicorp-aws/hashicorp/webservice/images/
- name: QubitPi/hashicorp-aws
uses: QubitPi/hashicorp-aws@master
with:
hashicorp-dir: ../hashicorp-aws/hashicorp/webservice
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: ${{ secrets.AWS_REGION }}