-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathliquibase.flowfile.cd.yaml
221 lines (217 loc) · 7.78 KB
/
liquibase.flowfile.cd.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
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
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
###
### This flowfile is intended to highlight capabilities of Liquibase Pro
### Review and update prior to use
###
### Liquibase version: 4.30.0+
###
### Liquibase sales: https://www.liquibase.com/contact-us
### Liquibase support: https://support.liquibase.com
###
###
### Prior to running the following files must exist in repository
###
### 1. liquibase.checks-settings.conf
### Liquibase policy checks configuration file
### https://docs.liquibase.com/liquibase-pro/policy-checks/home.html
###
### 2. changelog.main.xml
### Root Liquibase changelog file
### https://docs.liquibase.com/concepts/changelogs/home.html
###
###
### Global variables used in the flowfile
###
globalVariables:
###
### These variables are typically set via automation tools (see pipeline examples)
### NOTE: Any LIQUIBASE_* variable must be set outside this flow file!
### Value after ":-" in assignment is default value
###
### LIQUIBASE_SEARCH_PATH: REQUIRED
### https://docs.liquibase.com/parameters/search-path.html
### Use absolute paths when using Liquibase's Docker container
### LIQUIBASE_SEARCH_PATH: "/liquibase/changelog"
###
### LIQUIBASE_COMMAND_CHANGELOG_FILE: REQUIRED
### Root Liquibase changelog file
### https://docs.liquibase.com/concepts/changelogs/home.html
### LIQUIBASE_COMMAND_CHANGELOG_FILE: "changelog.main.xml"
###
### Secrets: REQUIRED
### These variables should be pulled from a secure vault via pipeline or Liquibase Pro extension
### https://docs.liquibase.com/tools-integrations/extensions/secrets-management/home.html
###
### LIQUIBASE_COMMAND_URL: "jdbc:h2:tcp://localhost:9090/mem:dev"
### LIQUIBASE_COMMAND_USERNAME: "dbuser"
### LIQUIBASE_COMMAND_PASSWORD: "letmein"
### LIQUIBASE_LICENSE_KEY: "12345"
###
### Structured logging
### Liquibase logs can be ingested by any standard observability tool (e.g., CloudWatch, Datadog, Elastic, Splunk)
### https://docs.liquibase.com/tools-integrations/observability/structured-logging.html
###
### LIQUIBASE_LOG_FILE: "liquibase.log.json"
### LIQUIBASE_LOG_FORMAT: "json"
### LIQUIBASE_LOG_LEVEL: "warning"
### LIQUIBASE_MIRROR_CONSOLE_MESSAGES_TO_LOG: "false"
###
### Other settings
### LIQUIBASE_COMMAND_CHECKS_RUN_CHECKS_OUTPUT: "issues"
### LIQUIBASE_COMMAND_CHECKS_RUN_CHECKS_SCRIPTS_ENABLED: "true"
### LIQUIBASE_SHOW_BANNER: "false"
###
### LB_BASE_DIR: REQUIRED
### The directory to write Liquibase output (e.g., logs, reports)
### LB_BASE_DIR: "/liquibase/changelogs"
LB_BASE_DIR: "${LB_BASE_DIR:-.}"
###
### LB_ENVIRONMENT: REQUIRED
### The environment within the pipeline to operate on (e.g., DEV, UAT, PROD)
### LB_ENVIRONMENT: "DEV"
LB_ENVIRONMENT: "${LB_ENVIRONMENT:-DEV}"
###
### LB_LABELS
### Used to specify which changesets to deploy (defaults to all)
### Set LB_LABELS variable from automation tool
### https://docs.liquibase.com/concepts/changelogs/attributes/labels.html
###
LB_LABELS: "${LB_LABELS:-null}"
###
### LB_TAG
### Used to specify the database tag
### Should be a unique identifier and change each run (e.g., job/build number)
### https://docs.liquibase.com/commands/utility/tag.html
LB_TAG: "${LB_TAG:-LBPRO}"
###
### Files
###
BASE_FLOW_FILE: "liquibase.flowfile.base.yaml"
DIFF_FILE: "Diff_${LB_ENVIRONMENT}.json"
SNAPSHOT_FILE: "Snapshot_${LB_ENVIRONMENT}.json"
###
### Operational Reports
### Liquibase Pro creates operational reports for certain commands
### These reports can be copied to a shared location for distribution to users (e.g., S3)
### https://docs.liquibase.com/tools-integrations/observability/operation-reports.html
###
DRIFT_REPORT: "Diff_${LB_ENVIRONMENT}.html"
ROLLBACK_REPORT: "Rollback_${LB_ENVIRONMENT}.html"
UPDATE_REPORT: "Update_${LB_ENVIRONMENT}.html"
###
### Workflow features
### Set these flags to T/F to turn Liquibase Pro features on/off
### These flags can also be set dynamically by an automation tool based on user input, environment, team, etc.
###
LB_SHOW_UPDATE_SQL: "${LB_SHOW_UPDATE_SQL:-F}"
LB_TEST_DRIFT: "${LB_TEST_DRIFT:-T}"
LB_TEST_ROLLBACKS: "${LB_TEST_ROLLBACKS:-F}"
###
### Stages to execute
###
stages:
Verify:
actions:
#
# Execute base commands
#
- type: liquibase
command: flow
cmdArgs: { flow-file: "${BASE_FLOW_FILE}" }
#
# View pending changes
# https://docs.liquibase.com/commands/change-tracking/status.html
#
- type: liquibase
command: status
cmdArgs: { label-filter: "${LB_LABELS}" }
DriftDetection:
actions:
#
# Run diff and check for drift
# Update referenceURL database type in cmdArgs (e.g., oracle, mssql, snowflake, etc.)
# https://docs.liquibase.com/commands/inspection/diff.html
#
- type: liquibase
if: "exists('${SNAPSHOT_FILE}', false) && ${LB_TEST_DRIFT} == 'T'"
command: diff
globalArgs: { outputfile: "${LB_BASE_DIR}/${DIFF_FILE}" }
cmdArgs: { drift-severity: "1", report-enabled: "true", report-path: "${LB_BASE_DIR}", report-name: "${DRIFT_REPORT}", referenceURL: "offline:mssql?snapshot=${SNAPSHOT_FILE}", format: json }
Deploy:
actions:
#
# Exit if no pending changes
# https://docs.liquibase.com/liquibase-pro/flow/home.html
#
- type: control
if: "status.changesetCount == 0"
command: exit
cmdArgs: { exitCode: "0", exitMessage: "Database is current!" }
#
# Tag database
# https://docs.liquibase.com/commands/utility/tag.html
#
- type: liquibase
command: tag
cmdArgs: { tag: "${LB_TAG}" }
#
# View pending SQL
# https://docs.liquibase.com/commands/update/update-sql.html
#
- type: liquibase
if: "${LB_SHOW_UPDATE_SQL} == 'T'"
command: update-sql
cmdArgs: { label-filter: "${LB_LABELS}" }
#
# Update database
# https://docs.liquibase.com/commands/update/update.html
#
- type: liquibase
command: update
cmdArgs: { label-filter: "${LB_LABELS}", report-enabled: "true", report-path: "${LB_BASE_DIR}", report-name: "${UPDATE_REPORT}" }
#
# Test rollbacks - view sql
# Typically non-production only
# https://docs.liquibase.com/commands/rollback/rollback-one-update-sql.html
#
- type: liquibase
if: "${LB_TEST_ROLLBACKS} == 'T' && !CONTAINS('${LB_ENVIRONMENT}', 'PROD')"
command: rollback-one-update-sql
#
# Test rollbacks - rollback last deployment
# Typically non-production only
# https://docs.liquibase.com/commands/rollback/rollback-one-update.html
#
- type: liquibase
if: "${LB_TEST_ROLLBACKS} == 'T' && !CONTAINS('${LB_ENVIRONMENT}', 'PROD')"
command: rollback-one-update
cmdArgs: { force: "true", report-enabled: "true", report-path: "${LB_BASE_DIR}", report-name: "${ROLLBACK_REPORT}" }
#
# Test rollbacks - reapply changes
# Typically non-production only
# https://docs.liquibase.com/commands/update/update.html
#
- type: liquibase
if: "${LB_TEST_ROLLBACKS} == 'T' && !CONTAINS('${LB_ENVIRONMENT}', 'PROD')"
command: update
cmdArgs: { label-filter: "${LB_LABELS}", report-enabled: "true", report-path: "${LB_BASE_DIR}", report-name: "${UPDATE_REPORT}" }
PostDeploy:
actions:
#
# Create updated snapshot
# https://docs.liquibase.com/commands/inspection/snapshot.html
#
- type: liquibase
command: snapshot
globalArgs: { outputfile: "${LB_BASE_DIR}/${SNAPSHOT_FILE}" }
cmdArgs: { snapshotFormat: "json" }
###
### Always execute
###
endStage:
actions:
#
# Show deployed changes
# https://docs.liquibase.com/commands/change-tracking/history.html
#
- type: liquibase
command: history