Skip to content

temp: temp 로 풀기 #199

temp: temp 로 풀기

temp: temp 로 풀기 #199

Workflow file for this run

name: CI (빌드 및 테스트)
on:
pull_request:
branches:
- master
- develop
- 'weekly/**'
<<<<<<< HEAD

Check failure on line 10 in .github/workflows/ci.yml

View workflow run for this annotation

GitHub Actions / .github/workflows/ci.yml

Invalid workflow file

You have an error in your yaml syntax on line 10
=======
permissions:
contents: write
issues: write
pull-requests: write
>>>>>>> weekly/11
jobs:
build-and-test:
runs-on: ubuntu-22.04
services:
mysql:
image: mysql:8.0
env:
MYSQL_DATABASE: ${{ secrets.MYSQL_DATABASE }}
MYSQL_USER: ${{ secrets.MYSQL_USER }}
MYSQL_PASSWORD: ${{ secrets.MYSQL_PASSWORD }}
MYSQL_ROOT_PASSWORD: ${{ secrets.MYSQL_ROOT_PASSWORD }}
ports:
- 3306:3306
options: >-
--health-cmd="mysqladmin ping -h localhost"
--health-interval=10s
--health-timeout=5s
--health-retries=5
redis:
image: redis
ports:
- 6379:6379
steps:
- name: Checkout Repository
uses: actions/checkout@v2
<<<<<<< HEAD
# - name: Cache Gradle dependencies
# uses: actions/cache@v3
# with:
# path: |
# ~/.gradle/caches/modules-2/files-2.1
# ~/.gradle/wrapper
# key: gradle-${{ runner.os }}-${{ hashFiles('build.gradle', 'settings.gradle') }}
# restore-keys: |
# gradle-${{ runner.os }}-
=======
>>>>>>> weekly/11
- name: Decode env.properties from GitHub Secrets
run: |
echo "${{ secrets.ENV_FILE }}" | base64 --decode > ./src/main/resources/env.properties
- name: Decode Firebase config from GitHub Secrets
run: |
echo "${{ secrets.FIREBASE_CONFIG }}" | base64 --decode > ./src/main/resources/splanet-firebase.json
- name: Set environment variables from env.properties
run: |
set -o allexport
source ./src/main/resources/env.properties
set +o allexport
- name: Set up JDK 21
uses: actions/setup-java@v2
with:
java-version: '21'
distribution: 'temurin'
- name: Wait for MySQL to be ready
run: |
for i in {30..0}; do
if docker exec $(docker ps -q --filter name=mysql) mysqladmin ping -h localhost; then
echo "MySQL is ready"
break
fi
echo "Waiting for MySQL..."
sleep 1
done
if [ $i -eq 0 ]; then
echo "MySQL did not become ready in time"
docker logs $(docker ps -q --filter name=mysql)
exit 1
fi
- name: Build with Gradle
<<<<<<< HEAD
run: ./gradlew build -Dspring.profiles.active=test
- name: Run Tests
run: ./gradlew test -Dspring.profiles.active=test
=======
run: ./gradlew clean build -Dspring.profiles.active=test
- name: Run Tests
run: ./gradlew test -Dspring.profiles.active=test
- name: Generate JaCoCo Coverage Report
run: ./gradlew jacocoTestReport
- name: Generate Coverage Badge and Summary
uses: cicirello/jacoco-badge-generator@v2
with:
jacoco-csv-file: 'build/reports/jacoco/test/jacocoTestReport.csv'
badges-directory: 'badges'
generate-branches-badge: true
generate-summary: true
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Display Coverage Summary JSON
run: |
cat badges/coverage-summary.json
- name: Extract Coverage Information
if: ${{ github.event_name == 'pull_request' }}
run: |
COVERAGE=$(jq '.coverage' badges/coverage-summary.json)
BRANCH_COVERAGE=$(jq '.branches' badges/coverage-summary.json)
FORMATTED_COVERAGE=$(printf "%.2f" $COVERAGE)
FORMATTED_BRANCH_COVERAGE=$(printf "%.2f" $BRANCH_COVERAGE)
curl -s -H "Authorization: token ${{ secrets.GITHUB_TOKEN }}" \
-X POST \
-d "{\"body\": \"### 코드 커버리지\n- Coverage: ${FORMATTED_COVERAGE}%\n- Branches: ${FORMATTED_BRANCH_COVERAGE}%\n\"}" \
"https://api.github.com/repos/${{ github.repository }}/issues/${{ github.event.pull_request.number }}/comments"
>>>>>>> weekly/11