From 894f53e3f07ed8295e81a1c35b699e767119fce1 Mon Sep 17 00:00:00 2001 From: Hiroyuki Yamada Date: Tue, 12 Mar 2024 10:48:23 +0900 Subject: [PATCH] Backport to branch(3.10) : Update CI to fix issues of SQL Server integration test (#1601) Co-authored-by: kota2and3kan <47254383+kota2and3kan@users.noreply.github.com> --- .github/workflows/ci.yaml | 9 ++- .../create-no-superuser-sqlserver.sh | 60 ++++++++++++++++++- 2 files changed, 64 insertions(+), 5 deletions(-) diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml index 4388b6f233..f7755b0d00 100644 --- a/.github/workflows/ci.yaml +++ b/.github/workflows/ci.yaml @@ -621,7 +621,8 @@ jobs: distribution: 'temurin' - name: Create no superuser - run: ./ci/no-superuser/create-no-superuser-sqlserver.sh sqlserver17 SqlServer17 + run: ./ci/no-superuser/create-no-superuser-sqlserver.sh sqlserver17 SqlServer17 10 3 + timeout-minutes: 1 - name: Setup and execute Gradle 'integrationTestJdbc' task uses: gradle/gradle-build-action@v2 @@ -660,7 +661,8 @@ jobs: distribution: 'temurin' - name: Create no superuser - run: ./ci/no-superuser/create-no-superuser-sqlserver.sh sqlserver19 SqlServer19 + run: ./ci/no-superuser/create-no-superuser-sqlserver.sh sqlserver19 SqlServer19 10 3 + timeout-minutes: 1 - name: Setup and execute Gradle 'integrationTestJdbc' task uses: gradle/gradle-build-action@v2 @@ -699,7 +701,8 @@ jobs: distribution: 'temurin' - name: Create no superuser - run: ./ci/no-superuser/create-no-superuser-sqlserver.sh sqlserver22 SqlServer22 + run: ./ci/no-superuser/create-no-superuser-sqlserver.sh sqlserver22 SqlServer22 10 3 + timeout-minutes: 1 - name: Setup and execute Gradle 'integrationTestJdbc' task uses: gradle/gradle-build-action@v2 diff --git a/ci/no-superuser/create-no-superuser-sqlserver.sh b/ci/no-superuser/create-no-superuser-sqlserver.sh index 0d08035d37..99601010d1 100755 --- a/ci/no-superuser/create-no-superuser-sqlserver.sh +++ b/ci/no-superuser/create-no-superuser-sqlserver.sh @@ -1,23 +1,79 @@ #!/bin/bash -set -eu +set -u # Get container name and password from arguments SQL_SERVER_CONTAINER_NAME=$1 SQL_SERVER_PASSWORD=$2 +MAX_RETRY_COUNT=$3 +RETRY_INTERVAL=$4 +COUNT=0 + +echo "INFO: Creating no superuser start." + +# A SQL Server container takes a few seconds to start SQL Server process +# in the container. So, first, we wait ${RETRY_INTERVAL} seconds before +# we run the `sqlcmd` command in the container. +echo "INFO: Sleep ${RETRY_INTERVAL} seconds to wait for SQL Server start." + +while [[ ${COUNT} -lt ${MAX_RETRY_COUNT} ]] +do + sleep ${RETRY_INTERVAL} + + echo "INFO: Retry count: ${COUNT}" + + docker exec -t ${SQL_SERVER_CONTAINER_NAME} /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P ${SQL_SERVER_PASSWORD} -d master -Q "SELECT 1" + if [[ $? -eq 0 ]]; then + break + else + echo "INFO: sqlcmd command failed. Will retry after ${RETRY_INTERVAL} seconds." + fi + + COUNT=$((COUNT + 1)) + + if [[ ${COUNT} -eq ${MAX_RETRY_COUNT} ]]; then + echo "ERROR: sqlcmd command failed ${MAX_RETRY_COUNT} times. Please check your configuration." >&2 + exit 1 + fi +done + +echo "INFO: sqlcmd command succeeded. Continue creating no superuser." # Create login +echo "INFO: Create login start" docker exec -t ${SQL_SERVER_CONTAINER_NAME} /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P ${SQL_SERVER_PASSWORD} -d master -Q "CREATE LOGIN no_superuser WITH PASSWORD = 'no_superuser_password', DEFAULT_DATABASE = master , CHECK_POLICY = OFF, CHECK_EXPIRATION = OFF" +echo "INFO: Create login end" # Create database -docker exec -t ${SQL_SERVER_CONTAINER_NAME} /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P ${SQL_SERVER_PASSWORD} -d master -Q "CREATE DATABASE test_db" +echo "INFO: Create database start" +docker exec -t ${SQL_SERVER_CONTAINER_NAME} /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P ${SQL_SERVER_PASSWORD} -d master -Q "CREATE DATABASE test_db COLLATE Japanese_BIN2" +echo "INFO: Create database end" # Create no_superuser +echo "INFO: Create no_superuser start" docker exec -t ${SQL_SERVER_CONTAINER_NAME} /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P ${SQL_SERVER_PASSWORD} -d test_db -Q "CREATE USER no_superuser FOR LOGIN no_superuser" +echo "INFO: Create no_superuser end" # Add roles +echo "INFO: Add role db_ddladmin start" docker exec -t ${SQL_SERVER_CONTAINER_NAME} /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P ${SQL_SERVER_PASSWORD} -d test_db -Q "EXEC sp_addrolemember @rolename = 'db_ddladmin', @membername = 'no_superuser'" +echo "INFO: Add role db_ddladmin end" + +echo "INFO: Add role db_datawriter start" docker exec -t ${SQL_SERVER_CONTAINER_NAME} /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P ${SQL_SERVER_PASSWORD} -d test_db -Q "EXEC sp_addrolemember @rolename = 'db_datawriter', @membername = 'no_superuser'" +echo "INFO: Add role db_datawriter end" + +echo "INFO: Add role db_datareader start" docker exec -t ${SQL_SERVER_CONTAINER_NAME} /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P ${SQL_SERVER_PASSWORD} -d test_db -Q "EXEC sp_addrolemember @rolename = 'db_datareader', @membername = 'no_superuser'" +echo "INFO: Add role db_datareader end" + +# Check the collation of test_db (for debugging purposes) +echo "INFO: Check collation start" +docker exec -t ${SQL_SERVER_CONTAINER_NAME} /opt/mssql-tools/bin/sqlcmd -S localhost -U no_superuser -P no_superuser_password -d test_db -Q "SELECT name, collation_name FROM sys.databases" -W +echo "INFO: Check collation end" # Check if no_superuser can access SQL Server (for debugging purposes) +echo "INFO: SELECT @@version start" docker exec -t ${SQL_SERVER_CONTAINER_NAME} /opt/mssql-tools/bin/sqlcmd -S localhost -U no_superuser -P no_superuser_password -d test_db -Q "SELECT @@version" +echo "INFO: SELECT @@version end" + +echo "INFO: Creating no superuser succeeded."