forked from octodemo-containers/bookstore-advanced
-
Notifications
You must be signed in to change notification settings - Fork 1
93 lines (77 loc) · 3.49 KB
/
create_deployment_label.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
name: Create Deployment by label
#
# A workflow that will respond to particular labels being added to a Pull Request to create an
# integration environment.
#
on:
pull_request:
types:
- labeled
jobs:
deployment:
name: Create deployment
runs-on: ubuntu-latest
if: |
github.event.label.name == 'Deploy to Test' ||
github.event.label.name == 'Deploy to Staging' ||
github.event.label.name == 'Deploy to QA'
steps:
- name: Checkout Sources
uses: actions/checkout@v2
- name: Acknowledge Request Label from Pull Request
id: acknowledge_label
uses: actions/github-script@v3
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
script: |
const scriptPath = require('path').resolve('./.github/workflows/scripts/deploymentLabel.js');
const DeploymentLabel = require(scriptPath);
const deploymentLabel = new DeploymentLabel(context, core, github);
await deploymentLabel.acknowledgeDeployLabel();
- name: Get temporary token for creating deployment
id: temp_token
uses: peter-murray/workflow-application-token-action@v1
with:
application_id: ${{ secrets.OCTODEMOBOT_APPLICATION_ID_REPO_AUTOMATION }}
application_private_key: ${{ secrets.OCTODEMOBOT_APPLICATION_KEY_REPO_AUTOMATION }}
- name: Create Deployment
uses: actions/github-script@v3
env:
container_registry: ghcr.io
app_container_image: ${{ steps.acknowledge_label.outputs.app_container_image }}
app_container_version: ${{ steps.acknowledge_label.outputs.app_container_version }}
db_container_image: ${{ steps.acknowledge_label.outputs.database_container_image }}
db_container_version: ${{ steps.acknowledge_label.outputs.database_container_version }}
with:
github-token: ${{ steps.temp_token.outputs.token }}
script: |
const scriptPath = require('path').resolve('./.github/workflows/scripts/create_deployment.js');
const createDeployment = require(scriptPath);
const LABEL_TO_ENVIRONMENT = {
'deploy to qa': 'qa',
'deploy to staging': 'staging',
'deploy to test': 'test'
};
await createDeployment({
context: context,
github: github,
environment: LABEL_TO_ENVIRONMENT[context.payload.label.name.toLowerCase()],
containerRegistry: process.env.container_registry,
appContainerImage: process.env.app_container_image,
appContainerVersion: process.env.app_container_version,
databaseContainerImage: process.env.db_container_image,
databaseContainerVersion: process.env.db_container_version,
sha: context.sha,
head: context.payload.pull_request.head.ref, //Branch name PR created from
});
- name: Report Failure
if: failure()
uses: actions/github-script@v3
with:
script: |
const commentBody = `Failure in _${context.payload.label.name.toLowerCase()}_, for more details see https://github.com/${context.repo.owner}/${context.repo.repo}/actions/runs/${process.env.GITHUB_RUN_ID}`;
await github.issues.createComment({
...context.repo,
issue_number: context.payload.number,
body: commentBody,
});