2025-03-21 15:14:53 +01:00
|
|
|
trigger: none # Because we trigger this only in PRs, no need to have triggers here
|
2025-03-18 13:41:40 +01:00
|
|
|
|
|
|
|
|
pool:
|
2025-03-18 15:55:45 +01:00
|
|
|
name: ci-pool-prd
|
2025-03-18 13:41:40 +01:00
|
|
|
|
|
|
|
|
steps:
|
|
|
|
|
- script: |
|
2025-03-18 17:23:57 +01:00
|
|
|
echo "Running on branch: ${BUILD_SOURCEBRANCH#refs/heads/}"
|
2025-03-21 15:20:37 +01:00
|
|
|
displayName: 'Print branch'
|
2025-03-18 17:23:57 +01:00
|
|
|
|
|
|
|
|
- script: |
|
|
|
|
|
cp ~/dbt-ci/.env .
|
2025-03-19 15:17:33 +01:00
|
|
|
|
2025-03-24 14:17:02 +01:00
|
|
|
if [[ $BUILD_SOURCEBRANCH =~ ^refs/pull/([0-9]+)/merge$ ]]; then
|
2025-03-24 14:21:05 +01:00
|
|
|
CI_SCHEMA_NAME="ci_pr_${BASH_REMATCH[1]}"
|
2025-03-24 14:17:02 +01:00
|
|
|
else
|
|
|
|
|
echo "Not running in a PR. Exiting"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
2025-03-19 15:17:33 +01:00
|
|
|
|
2025-03-24 14:17:02 +01:00
|
|
|
echo "CI_SCHEMA_NAME: $CI_SCHEMA_NAME"
|
2025-03-19 15:17:33 +01:00
|
|
|
|
2025-03-24 14:17:02 +01:00
|
|
|
echo "CI_SCHEMA_NAME=$CI_SCHEMA_NAME" >> .env
|
2025-03-18 17:23:57 +01:00
|
|
|
set -a && source .env && set +a
|
2025-03-24 14:17:02 +01:00
|
|
|
displayName: 'Prepare env vars'
|
2025-03-18 17:26:20 +01:00
|
|
|
|
|
|
|
|
- script: |
|
2025-03-18 17:31:05 +01:00
|
|
|
set -a && source .env && set +a
|
2025-03-18 17:33:49 +01:00
|
|
|
|
2025-03-18 17:26:20 +01:00
|
|
|
psql -h $POSTGRES_HOST -U $POSTGRES_USER -d postgres -c "SELECT 1 FROM pg_database WHERE datname = 'postgres';"
|
2025-03-18 17:33:49 +01:00
|
|
|
displayName: 'Smoke test Postgres connection'
|
|
|
|
|
|
2025-04-02 15:02:02 +02:00
|
|
|
- script: |
|
|
|
|
|
set -a && source .env && set +a
|
|
|
|
|
|
|
|
|
|
psql -h $POSTGRES_HOST -U $POSTGRES_USER -d prd-pointer -c "select refresh_foreign_schemas(ARRAY[$PRD_SCHEMAS_TO_SYNC]);"
|
|
|
|
|
displayName: 'Sync Foreign Data Wrappers schemas'
|
|
|
|
|
|
2025-03-21 12:15:50 +01:00
|
|
|
- script: |
|
2025-04-02 15:00:22 +02:00
|
|
|
cd ci
|
2025-03-21 12:15:50 +01:00
|
|
|
/bin/bash build-master-artifacts.sh
|
|
|
|
|
displayName: 'Build master artifacts'
|
|
|
|
|
|
2025-03-18 17:48:49 +01:00
|
|
|
- script: |
|
2025-03-18 17:51:51 +01:00
|
|
|
python3 -m venv venv
|
2025-03-18 17:48:49 +01:00
|
|
|
source venv/bin/activate
|
|
|
|
|
pip install -r requirements.txt
|
2025-03-20 12:39:43 +01:00
|
|
|
pip install -r ci/ci-requirements.txt
|
2025-03-18 17:48:49 +01:00
|
|
|
|
|
|
|
|
displayName: 'Create python virtual environment'
|
|
|
|
|
|
|
|
|
|
- script: |
|
|
|
|
|
source venv/bin/activate
|
|
|
|
|
dbt deps
|
|
|
|
|
|
|
|
|
|
displayName: 'Install dbt deps'
|
|
|
|
|
|
2025-03-18 17:38:55 +01:00
|
|
|
- script: |
|
2025-03-18 18:02:28 +01:00
|
|
|
source venv/bin/activate
|
|
|
|
|
set -a && source .env && set +a
|
2025-03-24 14:17:02 +01:00
|
|
|
export IS_CI_EXECUTION=1
|
2025-03-18 18:02:28 +01:00
|
|
|
|
2025-03-21 12:28:18 +01:00
|
|
|
dbt docs generate --no-compile --empty-catalog --select "state:modified" --state ~/dbt-ci/master-artifacts/
|
2025-03-18 18:02:28 +01:00
|
|
|
|
|
|
|
|
displayName: 'Run dbt docs'
|
|
|
|
|
|
2025-03-18 18:12:53 +01:00
|
|
|
- script: |
|
|
|
|
|
source venv/bin/activate
|
|
|
|
|
set -a && source .env && set +a
|
2025-03-24 14:17:02 +01:00
|
|
|
export IS_CI_EXECUTION=1
|
2025-03-18 18:12:53 +01:00
|
|
|
|
2025-03-21 15:20:37 +01:00
|
|
|
dbt compile --debug --select "state:modified" --state ~/dbt-ci/master-artifacts/
|
2025-03-18 18:12:53 +01:00
|
|
|
displayName: 'Run dbt compile'
|
|
|
|
|
|
2025-03-20 12:39:43 +01:00
|
|
|
- script: |
|
|
|
|
|
source venv/bin/activate
|
|
|
|
|
|
|
|
|
|
cd ci
|
|
|
|
|
/bin/bash sqlfluff-check.sh ../target/compiled
|
|
|
|
|
|
2025-03-21 15:02:47 +01:00
|
|
|
displayName: 'Validate models compiled SQL'
|
2025-03-20 12:39:43 +01:00
|
|
|
|
2025-03-24 12:11:23 +01:00
|
|
|
- script: |
|
|
|
|
|
set -a && source .env && set +a
|
|
|
|
|
|
2025-03-24 14:17:02 +01:00
|
|
|
psql -h $POSTGRES_HOST -U $POSTGRES_USER -d prd-pointer -c "DROP SCHEMA IF EXISTS $CI_SCHEMA_NAME CASCADE;"
|
2025-03-24 12:16:59 +01:00
|
|
|
|
|
|
|
|
displayName: "Preemptive DROP SCHEMA"
|
2025-03-24 12:11:23 +01:00
|
|
|
|
2025-03-21 16:53:22 +01:00
|
|
|
- script: |
|
|
|
|
|
source venv/bin/activate
|
|
|
|
|
set -a && source .env && set +a
|
2025-03-24 14:17:02 +01:00
|
|
|
export IS_CI_EXECUTION=1
|
2025-03-21 16:53:22 +01:00
|
|
|
|
|
|
|
|
dbt run --select "state:modified" --state ~/dbt-ci/master-artifacts/ --defer
|
|
|
|
|
|
|
|
|
|
displayName: 'Run modified models'
|
|
|
|
|
|
2025-03-24 12:11:23 +01:00
|
|
|
- script: |
|
|
|
|
|
source venv/bin/activate
|
|
|
|
|
set -a && source .env && set +a
|
2025-03-24 14:17:02 +01:00
|
|
|
export IS_CI_EXECUTION=1
|
2025-03-24 12:11:23 +01:00
|
|
|
|
|
|
|
|
dbt test --select "state:modified" --state ~/dbt-ci/master-artifacts/ --defer
|
|
|
|
|
|
|
|
|
|
displayName: 'Test modified models'
|
|
|
|
|
|
2025-03-24 12:22:43 +01:00
|
|
|
- script: |
|
|
|
|
|
source venv/bin/activate
|
|
|
|
|
set -a && source .env && set +a
|
2025-03-24 14:17:02 +01:00
|
|
|
export IS_CI_EXECUTION=1
|
2025-03-24 12:22:43 +01:00
|
|
|
|
2025-03-24 16:27:15 +01:00
|
|
|
dbt run --select "state:modified+1" --exclude "state:modified" --state ~/dbt-ci/master-artifacts/ --defer
|
2025-03-24 12:22:43 +01:00
|
|
|
|
2025-03-24 16:27:15 +01:00
|
|
|
displayName: 'Run direct dependants of modified models'
|
2025-03-24 12:22:43 +01:00
|
|
|
|
|
|
|
|
- script: |
|
|
|
|
|
source venv/bin/activate
|
|
|
|
|
set -a && source .env && set +a
|
2025-03-24 14:17:02 +01:00
|
|
|
export IS_CI_EXECUTION=1
|
2025-03-24 12:22:43 +01:00
|
|
|
|
2025-03-24 16:27:15 +01:00
|
|
|
dbt test --select "state:modified+1" --exclude "state:modified" --state ~/dbt-ci/master-artifacts/ --defer
|
2025-03-24 12:22:43 +01:00
|
|
|
|
2025-03-24 16:27:15 +01:00
|
|
|
displayName: 'Test direct dependants of modified models'
|
2025-03-24 12:22:43 +01:00
|
|
|
|
2025-03-24 12:11:23 +01:00
|
|
|
- script: |
|
|
|
|
|
set -a && source .env && set +a
|
2025-03-24 14:17:02 +01:00
|
|
|
psql -h $POSTGRES_HOST -U $POSTGRES_USER -d prd-pointer -c "DROP SCHEMA IF EXISTS $CI_SCHEMA_NAME CASCADE;"
|
2025-03-24 12:11:23 +01:00
|
|
|
|
|
|
|
|
condition: always()
|
|
|
|
|
displayName: 'Delete PR schema'
|