Skip to content

Merge pull request #40 from Anifriends/feat/#39 #40

Merge pull request #40 from Anifriends/feat/#39

Merge pull request #40 from Anifriends/feat/#39 #40

Workflow file for this run

name: CI-Backend
on:
push:
branches: [ "dev", "main" ]
pull_request:
branches: [ "dev", "main" ]
permissions:
contents: read
# PR ์ฝ”๋ฉ˜ํŠธ ๋“ฑ๋ก์„ ์œ„ํ•œ write ๊ถŒํ•œ
checks: write
pull-requests: write
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
# Java version ์„ธํŒ…
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '17'
distribution: 'temurin'
- name: Cache SonarCloud packages
uses: actions/cache@v3
with:
path: ~/.sonar/cache
key: ${{ runner.os }}-sonar
restore-keys: ${{ runner.os }}-sonar
# ๋นŒ๋“œ ์‹œ ์บ์‹œ ์ ์šฉ
- name: Gradle Caching
uses: actions/cache@v3
with:
path: |
~/.gradle/caches
~/.gradle/wrapper
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
restore-keys: |
${{ runner.os }}-gradle-
## gradle ๊ถŒํ•œ ์ฃผ๊ธฐ
- name: Grant execute permission for gradlew
run: chmod +x ./gradlew
shell: bash
# Build with sonar
- name: Build and analyze
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # Needed to get PR information, if any
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
run: ./gradlew build sonar --info
## ํ…Œ์ŠคํŠธ ๊ฒฐ๊ณผ PR ์ฝ”๋ฉ˜ํŠธ์— ๋“ฑ๋ก
- name: Register the test results as PR comments
uses: EnricoMi/publish-unit-test-result-action@v2
if: always()
with:
files: '**/build/test-results/test/TEST-*.xml'
## ํ…Œ์ŠคํŠธ ์‹คํŒจ์‹œ ์ฝ”๋“œ ๋ผ์ธ์— ๋Œ€ํ•œ ์ฒดํฌ ์ถ”๊ฐ€
- name: If test fail, add check comment on failed code line
uses: mikepenz/action-junit-report@v3
if: always()
with:
report_paths: '**/build/test-results/test/TEST-*.html'