-
Notifications
You must be signed in to change notification settings - Fork 1.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Jacob Beck
committed
Sep 11, 2018
1 parent
0cf38bc
commit 99a04e9
Showing
2 changed files
with
179 additions
and
0 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 |
---|---|---|
@@ -0,0 +1,94 @@ | ||
import mock | ||
import unittest | ||
|
||
import dbt.flags as flags | ||
|
||
import dbt.adapters | ||
from dbt.adapters.snowflake import SnowflakeAdapter | ||
from dbt.exceptions import ValidationException | ||
from dbt.logger import GLOBAL_LOGGER as logger # noqa | ||
from snowflake import connector as snowflake_connector | ||
|
||
class TestSnowflakeAdapter(unittest.TestCase): | ||
def setUp(self): | ||
flags.STRICT_MODE = False | ||
|
||
self.profile = { | ||
'dbname': 'postgres', | ||
'user': 'root', | ||
'host': 'database', | ||
'pass': 'password', | ||
'port': 5432, | ||
'schema': 'public' | ||
} | ||
|
||
self.project = { | ||
'name': 'X', | ||
'version': '0.1', | ||
'profile': 'test', | ||
'project-root': '/tmp/dbt/does-not-exist', | ||
'quoting': { | ||
'identifier': False, | ||
'schema': True, | ||
} | ||
} | ||
|
||
self.handle = mock.MagicMock(spec=snowflake_connector.SnowflakeConnection) | ||
self.cursor = self.handle.cursor.return_value | ||
self.mock_execute = self.cursor.execute | ||
self.patcher = mock.patch('dbt.adapters.snowflake.impl.snowflake.connector.connect') | ||
self.snowflake = self.patcher.start() | ||
|
||
self.snowflake.return_value = self.handle | ||
conn = SnowflakeAdapter.get_connection(self.profile) | ||
|
||
def tearDown(self): | ||
# we want a unique self.handle every time. | ||
SnowflakeAdapter.cleanup_connections() | ||
self.patcher.stop() | ||
|
||
def test_quoting_on_drop_schema(self): | ||
SnowflakeAdapter.drop_schema( | ||
profile=self.profile, | ||
project_cfg=self.project, | ||
schema='test_schema' | ||
) | ||
|
||
self.mock_execute.assert_has_calls([ | ||
mock.call('drop schema if exists "test_schema" cascade', None) | ||
]) | ||
|
||
def test_quoting_on_drop(self): | ||
SnowflakeAdapter.drop( | ||
profile=self.profile, | ||
project_cfg=self.project, | ||
schema='test_schema', | ||
relation='test_table', | ||
relation_type='table' | ||
) | ||
self.mock_execute.assert_has_calls([ | ||
mock.call('drop table if exists "test_schema".test_table cascade', None) | ||
]) | ||
|
||
def test_quoting_on_truncate(self): | ||
SnowflakeAdapter.truncate( | ||
profile=self.profile, | ||
project_cfg=self.project, | ||
schema='test_schema', | ||
table='test_table' | ||
) | ||
self.mock_execute.assert_has_calls([ | ||
mock.call('truncate table "test_schema".test_table', None) | ||
]) | ||
|
||
def test_quoting_on_rename(self): | ||
SnowflakeAdapter.rename( | ||
profile=self.profile, | ||
project_cfg=self.project, | ||
schema='test_schema', | ||
from_name='table_a', | ||
to_name='table_b' | ||
) | ||
self.mock_execute.assert_has_calls([ | ||
mock.call('alter table "test_schema".table_a rename to table_b', None) | ||
]) |