Skip to content

dev-pytest

dev-pytest #29

Workflow file for this run

name: dev-pytest
on:
push:
branches:
- dev
- release/**
workflow_dispatch:
pull_request:
types: [opened, reopened]
jobs:
build:
env:
SNOWFLAKE_PASSWORD: ${{ secrets.SCHEMACHANGE_SNOWFLAKE_PASSWORD }}
SNOWFLAKE_USER: ${{ secrets.SCHEMACHANGE_SNOWFLAKE_USER }}
SNOWFLAKE_ACCOUNT: ${{ secrets.SCHEMACHANGE_SNOWFLAKE_ACCOUNT }}
SNOWFLAKE_DATABASE: SCHEMACHANGE_DEMO
SNOWFLAKE_WAREHOUSE: SCHEMACHANGE_DEMO_WH
SNOWFLAKE_ROLE: SCHEMACHANGE_DEMO_DEPLOY
#SNOWFLAKE_CONNECTIONS_MYCONNECTION_PASSWORD: ${{ secrets.SCHEMACHANGE_SNOWFLAKE_PASSWORD }}
#SNOWFLAKE_CONNECTIONS_MYCONNECTION_ACCOUNT: ${{ secrets.SCHEMACHANGE_SNOWFLAKE_ACCOUNT }}
#SNOWFLAKE_CONNECTIONS_MYCONNECTION_USER: ${{ secrets.SCHEMACHANGE_SNOWFLAKE_USER }}
SCHEMACHANGE_BUILD_ID: ${{ github.run_id }}
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
scenario-name: [ 'basics_demo', 'citibike_demo', 'citibike_demo_jinja']
steps:
- uses: actions/checkout@v4
- name: Set up Python 3.11
uses: actions/setup-python@v5
with:
python-version: "3.11"
- name: Update pip
run: |
python -m pip install --upgrade pip
- name: Install dependencies
run: |
python -m pip install -e .[dev]
- name: Test with pytest
run: |
pytest
#- name: Setup SnowCLI connection file
# run: |
# echo "[connections]" > config.toml
# echo "[connections.myconnection]" >> config.toml
# chmod 0600 config.toml
#- name: Install snowcli
# run: |
# pip install snowflake-cli-labs
#- name: Test Default snowcli connection
# run: |
# snow --version
# echo "::group::Config Contents"
# more config.toml
# echo "::endgroup::"
# snow --config-file config.toml connection test -c myconnection
# echo "Tested SnowCLI connection successfully!"
# echo "Set default connection"
# snow --config-file config.toml connection set-default "myconnection"
- name: Test Schemachange - ${{ matrix.scenario-name }}
env:
SCENARIO_NAME: ${{ matrix.scenario-name }}
run: |
export MY_TARGET_SCHEMA="${SCENARIO_NAME}_${{ env.SCHEMACHANGE_BUILD_ID }}"
echo "::group::Setting up ${MY_TARGET_SCHEMA}"
schemachange --config-folder ./demo/setup/${SCENARIO_NAME}
echo "::endgroup::"
echo "Testing Rendering to ${MY_TARGET_SCHEMA}"
echo "Work in Progress - To be Tested"
echo "::group::Testing Deployment using ${MY_TARGET_SCHEMA}"
schemachange --config-folder ./demo/${SCENARIO_NAME}
echo "::endgroup::"
echo "::group::Tearing down up ${MY_TARGET_SCHEMA}"
schemachange --config-folder ./demo/teardown/${SCENARIO_NAME}
echo "::endgroup::"
#- name: Test Citibike Demo
# run: |
# snow --config-file config.toml sql -f ./demo/setup/setup_citibike_demo.sql
# schemachange --config-folder ./demo/citibike
# snow --config-file config.toml sql -f ./demo/teardown/teardown_citibike_demo.sql
#- name: Test Citibike Demo Jinja Template
# run: |
# snow --config-file config.toml sql -f ./demo/setup/setup_citibike_demo_jinja.sql
# schemachange --config-folder ./demo/citibike_jinja
# snow --config-file config.toml sql -f ./demo/teardown/teardown_citibike_demo_jinja.sql