From 9e46e66688f1f111e54fe5fd8b46178fd87c4f42 Mon Sep 17 00:00:00 2001 From: MarkBNinetyOne Date: Mon, 15 Jul 2024 17:49:14 +0200 Subject: [PATCH] use pyodbc instead --- modules/mssql/testcontainers/mssql/__init__.py | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/modules/mssql/testcontainers/mssql/__init__.py b/modules/mssql/testcontainers/mssql/__init__.py index 6cee3681..cd966dd5 100644 --- a/modules/mssql/testcontainers/mssql/__init__.py +++ b/modules/mssql/testcontainers/mssql/__init__.py @@ -21,6 +21,11 @@ class SqlServerContainer(DbContainer): ... engine = sqlalchemy.create_engine(mssql.get_connection_url()) ... with engine.begin() as connection: ... result = connection.execute(sqlalchemy.text("select @@VERSION")) + + Notes + ----- + Requires `ODBC Driver 17 for SQL Server `_. """ def __init__( @@ -31,6 +36,7 @@ def __init__( port: int = 1433, dbname: str = "tempdb", dialect: str = "mssql+pymssql", + driver: str = "ODBC Driver 17 for SQL Server", **kwargs, ) -> None: raise_for_deprecated_parameter(kwargs, "user", "username") @@ -43,6 +49,7 @@ def __init__( self.username = username self.dbname = dbname self.dialect = dialect + self.driver = driver def _configure(self) -> None: self.with_env("SA_PASSWORD", self.password) @@ -56,6 +63,8 @@ def _connect(self) -> None: assert status == 0, "Cannot run 'SELECT 1': container is not ready" def get_connection_url(self) -> str: - return super()._create_connection_url( + base_url = super()._create_connection_url( dialect=self.dialect, username=self.username, password=self.password, dbname=self.dbname, port=self.port ) + url = base_url + f"?driver={'+'.join(self.driver.split(' '))}" + return url