-
Notifications
You must be signed in to change notification settings - Fork 37
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Backport to branch(3.12) : Update CI to fix issues of SQL Server inte…
…gration test (#1599) Co-authored-by: kota2and3kan <[email protected]>
- Loading branch information
1 parent
ab9d46a
commit 4af7852
Showing
2 changed files
with
64 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -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." |