-
Notifications
You must be signed in to change notification settings - Fork 46
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Used dbapi-compliance [1] package to test module according to pep-249 specification. Not implemented features are skipped in the tests. Added dbapi-compliance package to test.sh requirements and appveyor.yml [1] https://github.com/baztian/dbapi-compliance/
- Loading branch information
Showing
4 changed files
with
135 additions
and
3 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
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,131 @@ | ||
# -*- coding: utf-8 -*- | ||
|
||
from __future__ import print_function | ||
|
||
import sys | ||
import unittest | ||
|
||
import dbapi20 | ||
|
||
import tarantool | ||
from tarantool import dbapi | ||
from .lib.tarantool_server import TarantoolServer | ||
|
||
|
||
class TestSuite_DBAPI(dbapi20.DatabaseAPI20Test): | ||
table_prefix = 'dbapi20test_' # If you need to specify a prefix for tables | ||
|
||
ddl0 = 'create table %s (id INTEGER PRIMARY KEY AUTOINCREMENT, ' \ | ||
'name varchar(20))' | ||
ddl1 = 'create table %sbooze (name varchar(20) primary key)' % table_prefix | ||
ddl2 = 'create table %sbarflys (name varchar(20) primary key, ' \ | ||
'drink varchar(30))' % table_prefix | ||
|
||
@classmethod | ||
def setUpClass(self): | ||
print(' DBAPI '.center(70, '='), file=sys.stderr) | ||
print('-' * 70, file=sys.stderr) | ||
self.srv = TarantoolServer() | ||
self.srv.script = 'unit/suites/box.lua' | ||
self.srv.start() | ||
self.con = tarantool.Connection(self.srv.host, self.srv.args['primary']) | ||
self.driver = dbapi | ||
self.connect_kw_args = dict( | ||
host=self.srv.host, | ||
port=self.srv.args['primary']) | ||
|
||
def setUp(self): | ||
# prevent a remote tarantool from clean our session | ||
if self.srv.is_started(): | ||
self.srv.touch_lock() | ||
self.con.flush_schema() | ||
|
||
# grant full access to guest | ||
self.srv.admin("box.schema.user.grant('guest', 'create,read,write," | ||
"execute', 'universe')") | ||
|
||
@classmethod | ||
def tearDownClass(self): | ||
self.con.close() | ||
self.srv.stop() | ||
self.srv.clean() | ||
|
||
def test_rowcount(self): | ||
con = self._connect() | ||
try: | ||
cur = con.cursor() | ||
self.executeDDL1(cur) | ||
dbapi20._failUnless(self,cur.rowcount in (-1, 1), | ||
'cursor.rowcount should be -1 or 1 after executing no-result ' | ||
'statements' + str(cur.rowcount) | ||
) | ||
cur.execute("%s into %sbooze values ('Victoria Bitter')" % ( | ||
self.insert, self.table_prefix | ||
)) | ||
dbapi20._failUnless(self,cur.rowcount == 1, | ||
'cursor.rowcount should == number or rows inserted, or ' | ||
'set to -1 after executing an insert statement' | ||
) | ||
cur.execute("select name from %sbooze" % self.table_prefix) | ||
dbapi20._failUnless(self,cur.rowcount == -1, | ||
'cursor.rowcount should == number of rows returned, or ' | ||
'set to -1 after executing a select statement' | ||
) | ||
self.executeDDL2(cur) | ||
dbapi20._failUnless(self,cur.rowcount in (-1, 1), | ||
'cursor.rowcount should be -1 or 1 after executing no-result ' | ||
'statements' | ||
) | ||
finally: | ||
con.close() | ||
|
||
@unittest.skip('Not implemented') | ||
def test_Binary(self): | ||
pass | ||
|
||
@unittest.skip('Not implemented') | ||
def test_STRING(self): | ||
pass | ||
|
||
@unittest.skip('Not implemented') | ||
def test_BINARY(self): | ||
pass | ||
|
||
@unittest.skip('Not implemented') | ||
def test_NUMBER(self): | ||
pass | ||
|
||
@unittest.skip('Not implemented') | ||
def test_DATETIME(self): | ||
pass | ||
|
||
@unittest.skip('Not implemented') | ||
def test_ROWID(self): | ||
pass | ||
|
||
@unittest.skip('Not implemented') | ||
def test_Date(self): | ||
pass | ||
|
||
@unittest.skip('Not implemented') | ||
def test_Time(self): | ||
pass | ||
|
||
@unittest.skip('Not implemented') | ||
def test_Timestamp(self): | ||
pass | ||
|
||
@unittest.skip('Not implemented as optional.') | ||
def test_nextset(self): | ||
pass | ||
|
||
@unittest.skip('Not implemented') | ||
def test_callproc(self): | ||
pass | ||
|
||
def test_setoutputsize(self): # Do nothing | ||
pass | ||
|
||
@unittest.skip('Not implemented') | ||
def test_description(self): | ||
pass |