Skip to content

AUTO_COMMIT: Update CHANGELOG.md #360

AUTO_COMMIT: Update CHANGELOG.md

AUTO_COMMIT: Update CHANGELOG.md #360

Workflow file for this run

# ---------------------------------
# _____ __ __ ______ _
# / ___// /_ ___ / /________ ____ / ____/__ ______________ ______(_)
# \__ \/ __ \/ _ \/ / ___/ __ \/ __ \ / /_ / _ \/ ___/ ___/ __ `/ ___/ /
# ___/ / / / / __/ (__ ) /_/ / / / / / __/ / __/ / / / / /_/ / / / /
# /____/_/ /_/\___/_/____/\____/_/ /_/ /_/ \___/_/ /_/ \__,_/_/ /_/
# ---------------------------------
# Currency Conversion API
# GitHub Actions CI/CD workflow for the Java project with Maven
# - Runs on push or pull request to the master branch
# - Checks commit message to decide whether to skip changelog update
# - Sets up JDK 17
# - Installs Groovy if needed
# - Generates necessary SVG images for Markdown Documentation - PlantUML
# - Generates and checks changes in CHANGELOG.md, .env, swagger.json, swagger.yaml, and DIRECTORY.md
# - Uploads files if changed
# - Cleans up local repository
# - Maven package cache
# - Installs dependencies
# - Runs tests
# ---------------------------------
# ---------------------------------
# workflow name
# ---------------------------------
name: Build and Test Java Project with Maven
# ---------------------------------
# Events that trigger the workflow
# ---------------------------------
on:
push:
branches: [ master ]
pull_request:
branches: [ master ]
permissions:
contents: write # Permite leitura e escrita no repositório
jobs:
build:
# ---------------------------------
# Defines that the job will run on the latest Ubuntu environment
# ---------------------------------
runs-on: ubuntu-latest
steps:
# ---------------------------------
# Checkout the repository
# ---------------------------------
- name: Check out the repository
id: check-out-repository
uses: actions/checkout@v2
with:
fetch-depth: 0 # Obtém todo o histórico para todas as branches e tags
# ---------------------------------
# Checks the commit message to determine which files to update
# ---------------------------------
- name: Check if is primary
id: check-is_primary
run: |
COMMIT_MESSAGE=$(git log -1 --pretty=%B)
if [[ "$COMMIT_MESSAGE" == AUTO_COMMIT:* || "$COMMIT_MESSAGE" == "Render PlantUML files" ]]; then
echo "is_primary=false" >> $GITHUB_ENV
else
echo "is_primary=true" >> $GITHUB_ENV
fi
# ---------------------------------
# Generates PlantUML
# ---------------------------------
- name: Generate PlantUML diagrams
id: generate-plantuml-diagrams
if: env.is_primary == 'true'
uses: grassedge/generate-plantuml-action@master
with:
path: sys/uml
message: "Render PlantUML files"
env:
GITHUB_TOKEN: ${{ secrets.TOKEN }}
# ---------------------------------
# Sets up JDK 17
# ---------------------------------
- name: Set up JDK 17
id: setup-jdk
if: env.is_primary == 'true'
uses: actions/setup-java@v4
with:
distribution: 'adopt'
java-version: '17'
# ---------------------------------
# Step to cache Maven packages
# ---------------------------------
- name: Cache Maven packages
id: cache-maven-package
if: env.is_primary == 'true'
uses: actions/cache@v4
with:
path: ~/.m2/repository
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }}
restore-keys: ${{ runner.os }}-maven
# ---------------------------------
# Set up Python
# ---------------------------------
- name: Set up Python
if: env.is_primary == 'true'
uses: actions/setup-python@v2
with:
python-version: '3.12.4' # Especificando a versão do Python
# ---------------------------------
# Install Python dependencies
# ---------------------------------
- name: Install Python dependencies
if: env.is_primary == 'true'
run: |
python -m pip install --upgrade pip
pip install markdown2 weasyprint pygments markdown pdfkit PyPDF2
pip install requests
# ---------------------------------
# Installs Groovy if needed
# ---------------------------------
- name: Install Groovy
id: install-groovy
if: env.is_primary == 'true'
run: |
sudo apt-get install -y groovy
# ---------------------------------
# Caches Maven packages if no file needs to be updated
# ---------------------------------
- name: Cache Maven packages
id: cache-maven-packages
if: env.is_primary == 'true'
uses: actions/cache@v4
with:
path: ~/.m2/repository
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }}
restore-keys: ${{ runner.os }}-maven
# ---------------------------------
# Installs dependencies if no file needs to be updated
# ---------------------------------
- name: Install dependencies
id: install-depencencies
if: env.is_primary == 'true'
run: mvn clean install -Pci-cd -DskipTests
# ---------------------------------
# Gets the SHA of specified files if they exist and sets them as environment variables
# Files: CHANGELOG.md, .env, DIRECTORY.md, openapi/swagger.json, openapi/swagger.yaml
# ---------------------------------
- name: Get SHA of files if they exist
if: env.is_primary == 'true'
id: get-sha
run: |
# Function to get the SHA of a file and set it as an environment variable
get_sha() {
local file_path=$1
local var_name=$2
local sha=$(curl -s -H "Authorization: Bearer $GITHUB_TOKEN" -H "Accept: application/vnd.github.v3+json" https://api.github.com/repos/${{ github.repository }}/contents/$file_path | jq -r .sha)
if [ "$sha" != "null" ]; then
echo "${var_name}=${sha}" >> $GITHUB_ENV
else
echo "${var_name}=" >> $GITHUB_ENV
fi
}
get_sha "CHANGELOG.md" "changelog_sha"
get_sha ".env" "env_sha"
get_sha "DIRECTORY.md" "directory_sha"
get_sha "openapi/swagger.json" "swagger_json_sha"
get_sha "openapi/swagger.yaml" "swagger_yaml_sha"
env:
GITHUB_TOKEN: ${{ secrets.TOKEN }}
# ---------------------------------
# Checks if CHANGELOG.md, .env, DIRECTORY.md, swagger.json or swagger.yaml have changed
# ---------------------------------
- name: Check if CHANGELOG.md, .env, DIRECTORY.md, swagger.json or swagger.yaml have changed
if: env.is_primary == 'true'
id: check-changes
run: |
check_change() {
local file_path=$1
local remote_file=$(curl -s -H "Authorization: Bearer ${{ secrets.TOKEN }}" -H "Accept: application/vnd.github.v3.raw" https://api.github.com/repos/${{ github.repository }}/contents/$file_path | base64 -d || echo "")
local local_file=$(cat $file_path)
if [ "$remote_file" == "$local_file" ]; then
echo "No changes in $file_path"
exit 0
fi
}
check_change "CHANGELOG.md"
check_change ".env"
check_change "DIRECTORY.md"
check_change "openapi/swagger.json"
check_change "openapi/swagger.yaml"
# ---------------------------------
# Clean docs/site directory
# ---------------------------------
- name: Clean docs/site directory
if: env.is_primary == 'true'
run: |
rm -rf docs/site
# ---------------------------------
# Generates CHANGELOG.md, .env, swagger.json, swagger.yaml, and DIRECTORY.md if needed
# And Java doc in MD
# ---------------------------------
- name: Generate necessary files
id: generate-necessary-files
if: env.is_primary == 'true'
run: |
chmod +x sys/generateChangelogAndProjectVersion.groovy
groovy sys/generateChangelogAndProjectVersion.groovy
chmod +x sys/directory.groovy
groovy sys/directory.groovy
mvn clean install swagger:generate
mvn dokka:dokka
# ---------------------------------
# Adjust Markdown Table with Python
# ---------------------------------
- name: Adjust Markdown Table with Python
id: adjust-markdown-table-index
if: env.is_primary == 'true'
run: |
python sys/javadocmd.py
env:
PYTHONIOENCODING: UTF-8
- name: Generate CV PDFs
if: env.is_primary == 'true'
run: |
python sys/markdown_to_pdf.py
# - name: Upload PDF artifacts
# uses: actions/upload-artifact@v2
# with:
# name: cv-pdfs
# path: sys/pdf/*.pdf
- name: Upload all files from sys/pdf
if: env.is_primary == 'true'
run: |
# Navegar para o diretório correto
( cd sys/pdf
# Adicionar todos os arquivos modificados ao staging area do Git
git add .
# Verificar se há mudanças; se sim, fazer commit e push
if git diff --staged --quiet; then
echo "No changes to commit."
else
git config --global user.email "[email protected]"
git config --global user.name "Shelson Ferrari"
git commit -m "AUTO_COMMIT: Bulk update of documentation"
git push
fi )
env:
GITHUB_TOKEN: ${{ secrets.TOKEN3 }}
- name: Upload all files from docs/site
if: env.is_primary == 'true'
run: |
# Navegar para o diretório correto
( cd docs/site
# Adicionar todos os arquivos modificados ao staging area do Git
git add .
# Verificar se há mudanças; se sim, fazer commit e push
if git diff --staged --quiet; then
echo "No changes to commit."
else
git config --global user.email "[email protected]"
git config --global user.name "Shelson Ferrari"
git commit -m "AUTO_COMMIT: Bulk update of documentation"
git push
fi )
env:
GITHUB_TOKEN: ${{ secrets.TOKEN3 }}
# ---------------------------------
# Uploads CHANGELOG.md if it has changed
# ---------------------------------
- name: Upload CHANGELOG.md
id: upload-changelog
if: env.is_primary == 'true'
run: |
BASE64_CHANGELOG=$(base64 -w 0 CHANGELOG.md)
curl -X PUT \
-H "Authorization: Bearer ${{ secrets.TOKEN }}" \
-H "Accept: application/vnd.github.v3+json" \
https://api.github.com/repos/${{ github.repository }}/contents/CHANGELOG.md \
-d "$(jq -nc --arg content "$BASE64_CHANGELOG" --arg message "AUTO_COMMIT: Update CHANGELOG.md" --arg sha "$changelog_sha" --arg branch "${GITHUB_REF#refs/heads/}" '{message: $message, content: $content, sha: $sha, branch: $branch}')"
env:
GITHUB_TOKEN: ${{ secrets.TOKEN }}
# ---------------------------------
# Uploads .env if it has changed
# ---------------------------------
- name: Upload .env
id: upload-env
if: env.is_primary == 'true'
run: |
BASE64_ENV=$(base64 -w 0 .env)
curl -X PUT \
-H "Authorization: Bearer ${{ secrets.TOKEN }}" \
-H "Accept: application/vnd.github.v3+json" \
https://api.github.com/repos/${{ github.repository }}/contents/.env \
-d "$(jq -nc --arg content "$BASE64_ENV" --arg message "AUTO_COMMIT: Update .env" --arg sha "$env_sha" --arg branch "${GITHUB_REF#refs/heads/}" '{message: $message, content: $content, sha: $sha, branch: $branch}')"
env:
GITHUB_TOKEN: ${{ secrets.TOKEN }}
# ---------------------------------
# Uploads DIRECTORY.md if it has changed
# ---------------------------------
- name: Upload DIRECTORY.md
id: upload-directory
if: env.is_primary == 'true'
run: |
BASE64_DIRECTORY=$(base64 -w 0 DIRECTORY.md)
curl -X PUT \
-H "Authorization: Bearer ${{ secrets.TOKEN }}" \
-H "Accept: application/vnd.github.v3+json" \
https://api.github.com/repos/${{ github.repository }}/contents/DIRECTORY.md \
-d "$(jq -nc --arg content "$BASE64_DIRECTORY" --arg message "AUTO_COMMIT: Update DIRECTORY.md" --arg sha "$directory_sha" --arg branch "${GITHUB_REF#refs/heads/}" '{message: $message, content: $content, sha: $sha, branch: $branch}')"
env:
GITHUB_TOKEN: ${{ secrets.TOKEN }}
# ---------------------------------
# Checks and uploads swagger.json if changed
# ---------------------------------
- name: Upload swagger.json
id: upload-swagger-json
if: env.is_primary == 'true'
run: |
BASE64_SWAGGER_JSON=$(base64 -w 0 openapi/swagger.json)
curl -X PUT \
-H "Authorization: Bearer ${{ secrets.TOKEN }}" \
-H "Accept: application/vnd.github.v3+json" \
https://api.github.com/repos/${{ github.repository }}/contents/openapi/swagger.json \
-d "$(jq -nc --arg content "$BASE64_SWAGGER_JSON" --arg message "AUTO_COMMIT: Update swagger.json" --arg sha "$swagger_json_sha" --arg branch "${GITHUB_REF#refs/heads/}" '{message: $message, content: $content, sha: $sha, branch: $branch}')"
env:
GITHUB_TOKEN: ${{ secrets.TOKEN }}
# ---------------------------------
# Checks and uploads swagger.yaml if changed
# ---------------------------------
- name: Upload swagger.yaml
id: upload-swagger-yaml
if: env.is_primary == 'true'
run: |
BASE64_SWAGGER_YAML=$(base64 -w 0 openapi/swagger.yaml)
curl -X PUT \
-H "Authorization: Bearer ${{ secrets.TOKEN }}" \
-H "Accept: application/vnd.github.v3+json" \
https://api.github.com/repos/${{ github.repository }}/contents/openapi/swagger.yaml \
-d "$(jq -nc --arg content "$BASE64_SWAGGER_YAML" --arg message "AUTO_COMMIT: Update swagger.yaml" --arg sha "$swagger_yaml_sha" --arg branch "${GITHUB_REF#refs/heads/}" '{message: $message, content: $content, sha: $sha, branch: $branch}')"
env:
GITHUB_TOKEN: ${{ secrets.TOKEN }}
# ---------------------------------
# Check if is PlantUML upload SVG
# ---------------------------------
- name: Check if is PlantUML upload SVG
id: check-is-plantuml
run: |
COMMIT_MESSAGE=$(git log -1 --pretty=%B)
if [[ "$COMMIT_MESSAGE" == "Render PlantUML files" ]]; then
echo "is_plantuml=true" >> $GITHUB_ENV
else
echo "is_plantuml=false" >> $GITHUB_ENV
fi
# ---------------------------------
# Cleans up the local repository
# ---------------------------------
- name: Clean local repository
id: clean-local-repository
if: env.is_primary == 'true'
run: mvn dependency:purge-local-repository
# ---------------------------------
# Runs tests if no file needs to be updated
# ---------------------------------
- name: Run tests
id: run-tests
if: env.is_primary == 'true'
run: mvn test -Pci-cd