From 98d97ec2b0e68272bb0d04eabf6e718c68c14428 Mon Sep 17 00:00:00 2001 From: Fan Yang Date: Fri, 3 Jan 2025 01:22:33 +0800 Subject: [PATCH] test: correct replication table filtering test (#345) --- .github/workflows/replication-test.yml | 35 ++++++++++++++++---------- 1 file changed, 22 insertions(+), 13 deletions(-) diff --git a/.github/workflows/replication-test.yml b/.github/workflows/replication-test.yml index 597e272..d7d421f 100644 --- a/.github/workflows/replication-test.yml +++ b/.github/workflows/replication-test.yml @@ -174,19 +174,6 @@ jobs: exit 1 fi - # Verify skipped table is empty (for MySQL-compatible databases only) - if [ "${{ matrix.source }}" != "postgres" ]; then - # Check if skip table has any rows - COUNT=$(docker exec myduck psql -t -U postgres -h 127.0.0.1 -c \ - "SELECT COUNT(*) FROM ${SCHEMA}.skip;" | tr -d ' ') - if [ "$COUNT" -eq "0" ]; then - echo "Successfully verified that skipped table exists but is empty" - else - echo "Error: Skipped table 'skip' contains $COUNT rows when it should be empty" - exit 1 - fi - fi - - name: Test replication of new data run: | # Insert new data in source @@ -225,6 +212,28 @@ jobs: # Print the logs docker logs myduck + - name: Verify skip tables + run: | + # Verify skipped table is empty (for MySQL-compatible databases only) + if [ "${{ matrix.source }}" != "postgres" ]; then + # Check if skip table exists and has any rows + TABLE_EXISTS=$(docker exec myduck psql -t -U postgres -h 127.0.0.1 -c \ + "SELECT COUNT(*) FROM information_schema.tables WHERE table_schema = '${SCHEMA}' AND table_name = 'skip';" | tr -d ' ') + + if [ "$TABLE_EXISTS" -ne "0" ]; then + COUNT=$(docker exec myduck psql -t -U postgres -h 127.0.0.1 -c \ + "SELECT COUNT(*) FROM ${SCHEMA}.skip;" | tr -d ' ') + if [ "$COUNT" -eq "0" ]; then + echo "Successfully verified that skipped table exists but is empty" + else + echo "Error: Skipped table 'skip' contains $COUNT rows when it should be empty" + exit 1 + fi + else + echo "Successfully verified that skipped table does not exist in destination" + fi + fi + - name: Cleanup if: always() run: |