-
Notifications
You must be signed in to change notification settings - Fork 44
92 lines (80 loc) · 2.84 KB
/
latest-dev.yaml
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
name: Dev Deployment
on:
workflow_dispatch:
push:
branches:
- dev
jobs:
build-and-push:
if: github.event.repository.fork == false
environment:
name: "dev"
url: ${{ vars.URL }}
name: Build for dev
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Java with maven
uses: actions/setup-java@v4
with:
java-version: '17'
distribution: 'temurin'
cache: maven
- name: Create application-dev.properties
run: |
echo "spring.profiles.active=dev" > src/main/resources/application.properties
echo "${{ secrets.TEST_APP_PROPERTIES }}" | base64 --decode > src/main/resources/application-dev.properties
- name: Run the Maven verify phase
run: mvn clean install -Dmaven.test.skip=true
- name: copy service file
run: |
cp .github/scripts/java_dev_app.service target/
# cp ~/flyway.conf target/
# cp .env target/
- name: copy file via ssh password
uses: appleboy/[email protected]
with:
host: ${{ secrets.HOST }}
username: ${{ secrets.USERNAME }}
password: ${{ secrets.PASSWORD }}
source: "target/*"
target: /home/teamjava/hng_boilerplate_java_web
- name: Add SSH Key to Known Hosts
run: |
mkdir -p ~/.ssh
ssh-keyscan $SSH_HOST >> ~/.ssh/known_hosts
env:
SSH_HOST: ${{ secrets.HOST }}
- name: SSH into Server and Execute Command
run: |
sshpass -p $SSH_PASSWORD ssh -o StrictHostKeyChecking=no $SSH_USERNAME@$SSH_HOST "\
cd ~/hng_boilerplate_java_web && \
git fetch origin dev && \
git stash && \
git checkout dev && \
git pull && \
sudo cp .github/scripts/java_dev_app.service /etc/systemd/system/java_dev_app.service && \
sudo systemctl daemon-reload && \
sudo systemctl start java_dev_app.service && \
exit"
env:
SSH_HOST: ${{ secrets.HOST }}
SSH_USERNAME: ${{ secrets.USERNAME }}
SSH_PASSWORD: ${{ secrets.PASSWORD }}
- name: Verify Deployment
run: |
sshpass -p $SSH_PASSWORD ssh -o StrictHostKeyChecking=no $SSH_USERNAME@$SSH_HOST "\
sleep 60 && \
if sudo systemctl is-active --quiet java_dev_app.service; then \
echo 'Deployment successful!'; \
sudo systemctl stop java_dev_app.service && \
echo 'Dev application stopped after being stable for 60 seconds'; \
else \
echo 'Deployment failed!'; \
exit 1; \
fi"
env:
SSH_HOST: ${{ secrets.HOST }}
SSH_USERNAME: ${{ secrets.USERNAME }}
SSH_PASSWORD: ${{ secrets.PASSWORD }}