forked from soroushkavousi/fireplace-api
-
Notifications
You must be signed in to change notification settings - Fork 0
129 lines (102 loc) · 3.12 KB
/
CICD.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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
name: CICD
on:
push:
branches: [ "main" ]
pull_request:
branches: [ "main" ]
env:
FIREPLACE_API_ASPNETCORE_ENVIRONMENT: Production
FIREPLACE_API_LOG_DIRECTORY: /logs
FIREPLACE_API_CONNECTION_STRING: ${{ secrets.FIREPLACE_API_CONNECTION_STRING }}
jobs:
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Setup .NET
uses: actions/setup-dotnet@v2
with:
dotnet-version: 7.0.x
- name: Restore dependencies
run: dotnet restore
- name: Build
run: dotnet build --no-restore
- name: Test
run: dotnet test --no-build --logger "console;verbosity=detailed"
build:
needs: test
runs-on: ubuntu-latest
if: ${{ github.event_name == 'push' }}
steps:
- uses: actions/checkout@v3
- name: Setup .NET
uses: actions/setup-dotnet@v2
with:
dotnet-version: 7.0.x
- name: Publish
run: dotnet publish -c Release -o app
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Login to DockerHub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push
uses: docker/build-push-action@v3
with:
context: .
push: true
tags: fireplaceapi/fireplace-api:latest
deploy:
needs: build
runs-on: ubuntu-latest
if: ${{ github.event_name == 'push' }}
env:
SSH_PRIVATE_KEY_PATH: /home/runner/.ssh/private.key
PROJECT_DIRECTORY: /bitiano/projects/fireplace/fireplace-api/
steps:
- uses: actions/checkout@v3
- name: Create the private.key file
run: |
mkdir -p ~/.ssh/
echo "$SSH_PRIVATE_KEY" > $SSH_PRIVATE_KEY_PATH
chmod 600 $SSH_PRIVATE_KEY_PATH
env:
SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
- name: Create an SSH config for the server
run: |
cat >>~/.ssh/config <<END
Host server
HostName $SSH_HOST
User $SSH_USER
IdentityFile $SSH_PRIVATE_KEY_PATH
StrictHostKeyChecking no
END
env:
SSH_HOST: ${{ secrets.SSH_HOST }}
SSH_USER: ${{ secrets.SSH_USER }}
- name: Login to DockerHub
run: ssh server "docker login -u $DOCKERHUB_USERNAME -p $DOCKERHUB_TOKEN"
env:
DOCKERHUB_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }}
DOCKERHUB_TOKEN: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Transfer docker-compose.yml to the server
run: |
ssh server "mkdir -p $PROJECT_DIRECTORY"
scp docker-compose.yml server:$PROJECT_DIRECTORY
- name: Run the docker compose
run: ssh server "
cd $PROJECT_DIRECTORY;
ls -alh;
echo 'Running docker compose...';
export FIREPLACE_API_CONNECTION_STRING='$FIREPLACE_API_CONNECTION_STRING';
docker compose down -t 2;
docker compose pull;
docker compose up -d;
ls -alh;
"
- name: Logout from DockerHub
run: ssh server "docker logout"