-
Notifications
You must be signed in to change notification settings - Fork 0
98 lines (89 loc) · 5.88 KB
/
maven.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
# This workflow will build a Java project with Maven, and cache/restore any dependencies to improve the workflow execution time
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-java-with-maven
# This workflow uses actions that are not certified by GitHub.
# They are provided by a third-party and are governed by
# separate terms of service, privacy policy, and support
# documentation.
name: POD Booking System Server CI with Maven
on:
push:
branches: [ "main", "develop" ]
pull_request:
branches: [ "main", "develop" ]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up JDK 21
uses: actions/setup-java@v4
with:
java-version: '21'
distribution: 'temurin'
cache: maven
# Generate application.yml from environment variables
- name: Generate application.yml
run: |
mkdir -p src/main/resources
echo "server:" >> src/main/resources/application.yaml
echo " port: 8080" >> src/main/resources/application.yaml
echo "" >> src/main/resources/application.yaml
echo "openapi:" >> src/main/resources/application.yaml
echo " service: " >> src/main/resources/application.yaml
echo " api-docs: api-service" >> src/main/resources/application.yaml
echo " server: \"${{ secrets.SERVER_API_URL }}\"" >> src/main/resources/application.yaml
echo " title: API Service" >> src/main/resources/application.yaml
echo " version: 1.0.0" >> src/main/resources/application.yaml
echo "spring:" >> src/main/resources/application.yaml
echo " datasource:" >> src/main/resources/application.yaml
echo " url: \"${{ secrets.DATABASE_URL }}\"" >> src/main/resources/application.yaml
echo " username: \"${{ secrets.DATABASE_USERNAME }}\"" >> src/main/resources/application.yaml
echo " password: \"${{ secrets.DATABASE_PASSWORD }}\"" >> src/main/resources/application.yaml
echo " driver-class-name: com.mysql.cj.jdbc.Driver" >> src/main/resources/application.yaml
echo " jpa:" >> src/main/resources/application.yaml
echo " hibernate:" >> src/main/resources/application.yaml
echo " ddl-auto: update" >> src/main/resources/application.yaml
echo " naming:" >> src/main/resources/application.yaml
echo " implicit-strategy: org.hibernate.boot.model.naming.ImplicitNamingStrategyLegacyJpaImpl" >> src/main/resources/application.yaml
echo " physical-strategy: org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl" >> src/main/resources/application.yaml
echo " show-sql: true" >> src/main/resources/application.yaml
echo " mail:" >> src/main/resources/application.yaml
echo " host: \"${{ secrets.MAIL_HOST }}\"" >> src/main/resources/application.yaml
echo " port: \"${{ secrets.MAIL_PORT }}\"" >> src/main/resources/application.yaml
echo " username: \"${{ secrets.MAIL_USERNAME }}\"" >> src/main/resources/application.yaml
echo " password: \"${{ secrets.MAIL_PASSWORD }}\"" >> src/main/resources/application.yaml
echo " properties:" >> src/main/resources/application.yaml
echo " mail:" >> src/main/resources/application.yaml
echo " smtp:" >> src/main/resources/application.yaml
echo " auth: true" >> src/main/resources/application.yaml
echo " starttls:" >> src/main/resources/application.yaml
echo " enable: true" >> src/main/resources/application.yaml
echo " security:" >> src/main/resources/application.yaml
echo " oauth2:" >> src/main/resources/application.yaml
echo " client:" >> src/main/resources/application.yaml
echo " registration:" >> src/main/resources/application.yaml
echo " google:" >> src/main/resources/application.yaml
echo " client-id: \"${{ secrets.GOOGLE_CLIENT_ID }}\"" >> src/main/resources/application.yaml
echo " client-secret: \"${{ secrets.GOOGLE_CLIENT_SECRET }}\"" >> src/main/resources/application.yaml
echo " scope:" >> src/main/resources/application.yaml
echo " - email" >> src/main/resources/application.yaml
echo " - profile" >> src/main/resources/application.yaml
echo "" >> src/main/resources/application.yaml
echo "jwt:" >> src/main/resources/application.yaml
echo " JWT_SECRET_ACCESS_TOKEN: \"${{ secrets.JWT_SECRET_ACCESS_TOKEN }}\"" >> src/main/resources/application.yaml
echo " JWT_SECRET_REFRESH_TOKEN: \"${{ secrets.JWT_SECRET_REFRESH_TOKEN }}\"" >> src/main/resources/application.yaml
echo "" >> src/main/resources/application.yaml
echo "vnpay:" >> src/main/resources/application.yaml
echo " tmn-code: \"${{ secrets.VNPAY_TMN_CODE }}\"" >> src/main/resources/application.yaml
echo " hash-secret: \"${{ secrets.VNPAY_HASH_SECRET }}\"" >> src/main/resources/application.yaml
echo " return-url: \"${{ secrets.VNPAY_RETURN_URL }}\"" >> src/main/resources/application.yaml
echo " url: \"${{ secrets.VNPAY_URL }}\"" >> src/main/resources/application.yaml
- name: Build with Maven
run: mvn -B package --file pom.xml
- name: Display surefire test report
run: cat target/surefire-reports/*.txt
- name: Build with Maven (debug)
run: ./mvnw clean install -X
# # Optional: Uploads the full dependency graph to GitHub to improve the quality of Dependabot alerts this repository can receive
# - name: Update dependency graph
# uses: advanced-security/maven-dependency-submission-action@571e99aab1055c2e71a1e2309b9691de18d6b7d6