|
| 1 | +name: Clone Database to Unit Test |
| 2 | +description: Generates a test database |
| 3 | +inputs: |
| 4 | + working-directory: |
| 5 | + description: The directory where the scripts are located |
| 6 | + required: true |
| 7 | + source-database: |
| 8 | + description: The source database to clone |
| 9 | + required: true |
| 10 | + target-database: |
| 11 | + description: The target database name to clone to |
| 12 | + required: true |
| 13 | + snowflake-account: |
| 14 | + description: The Snowflake account name |
| 15 | + required: true |
| 16 | + snowflake-username: |
| 17 | + description: The Snowflake username |
| 18 | + required: true |
| 19 | + snowflake-password: |
| 20 | + description: The Snowflake password |
| 21 | + required: true |
| 22 | + snowflake-role: |
| 23 | + description: The Snowflake role |
| 24 | + required: true |
| 25 | + snowflake-warehouse: |
| 26 | + description: The Snowflake warehouse |
| 27 | + required: true |
| 28 | + data-lake-url: |
| 29 | + description: The Data Lake URL |
| 30 | + required: false |
| 31 | + storage-integration-name: |
| 32 | + description: The Storage Integration Name |
| 33 | + required: false |
| 34 | + |
| 35 | +runs: |
| 36 | + using: "composite" |
| 37 | + steps: |
| 38 | + - name: Find and replace target & source database name |
| 39 | + run: | |
| 40 | + sed -i 's/TARGET_DATABASE_NAME/${{ inputs.target-database }}/g' database-clone.sql |
| 41 | + sed -i 's/SOURCE_DATABASE_NAME/${{ inputs.source-database }}/g' database-clone.sql |
| 42 | + shell: pwsh |
| 43 | + working-directory: ${{ inputs.working-directory }} |
| 44 | + - name: Download SnowSQL |
| 45 | + shell: bash |
| 46 | + run: curl -O https://sfc-repo.snowflakecomputing.com/snowsql/bootstrap/1.2/linux_x86_64/snowsql-1.2.9-linux_x86_64.bash |
| 47 | + - name: Install SnowSQL |
| 48 | + shell: bash |
| 49 | + run: SNOWSQL_DEST=~/snowflake SNOWSQL_LOGIN_SHELL=~/.profile bash snowsql-1.2.9-linux_x86_64.bash |
| 50 | + - name: Execute SQL against Snowflake |
| 51 | + shell: bash |
| 52 | + run: | |
| 53 | + ~/snowflake/snowsql \ |
| 54 | + -a $SNOWSQL_ACCOUNT \ |
| 55 | + -u $SNOWSQL_USER \ |
| 56 | + -d $SNOWSQL_DATABASE \ |
| 57 | + -w $SNOWSQL_WAREHOUSE \ |
| 58 | + -f database-clone.sql |
| 59 | + env: |
| 60 | + SNOWSQL_ACCOUNT: ${{ inputs.snowflake-account }} |
| 61 | + SNOWSQL_USER: ${{ inputs.snowflake-username }} |
| 62 | + SNOWSQL_PWD: ${{ inputs.snowflake-password }} |
| 63 | + SNOWSQL_DATABASE: ${{ inputs.source-database }} |
| 64 | + SNOWSQL_WAREHOUSE: ${{ inputs.snowflake-warehouse }} |
| 65 | + working-directory: ${{ inputs.working-directory }} |
| 66 | + |
0 commit comments