forked from pymssql/pymssql
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrun_sqlalchemy_tests.py
More file actions
executable file
·69 lines (52 loc) · 1.87 KB
/
run_sqlalchemy_tests.py
File metadata and controls
executable file
·69 lines (52 loc) · 1.87 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# -*- coding: utf-8 -*-
"""
Run SQLAlchemy tests with pymssql connection.
"""
import configparser
import os
import sys
import tarfile
import urllib
SQLALCHEMY_VERSION = "1.2.11"
SQLALCHEMY_DIR = "SQLAlchemy-%s" % SQLALCHEMY_VERSION
SQLALCHEMY_TAR_GZ = "%s.tar.gz" % SQLALCHEMY_DIR
SQLALCHEMY_TAR_GZ_URL = "https://pypi.python.org/packages/source/S/SQLAlchemy/%s" % SQLALCHEMY_TAR_GZ
def download_sqlalchemy_tarball():
sys.stdout.write('Downloading %s... ' % SQLALCHEMY_TAR_GZ_URL)
sys.stdout.flush()
urllib.urlretrieve(SQLALCHEMY_TAR_GZ_URL, SQLALCHEMY_TAR_GZ)
sys.stdout.write('DONE\n')
def extract_sqlalchemy_tarball():
tarball = tarfile.open(SQLALCHEMY_TAR_GZ, 'r:gz')
sys.stdout.write('Extracting %s... ' % SQLALCHEMY_TAR_GZ)
sys.stdout.flush()
tarball.extractall('.')
sys.stdout.write('DONE\n')
def run_sqlalchemy_tests():
dburi = get_dburi()
if dburi:
sys.argv.append('--dburi=%s' % dburi)
os.chdir('SQLAlchemy-%s' % SQLALCHEMY_VERSION)
sys.path.append('.')
sys.stdout.write('Running SQLAlchemy tests...\n\n')
sys.stdout.flush()
import sqla_nose
def get_dburi():
config = configparser.SafeConfigParser()
config.read(os.path.join(os.path.dirname(__file__), 'tests.cfg'))
username = config.get('DEFAULT', 'username')
password = config.get('DEFAULT', 'password')
server = config.get('DEFAULT', 'server')
port = config.get('DEFAULT', 'port')
database = config.get('DEFAULT', 'database')
return 'mssql+pymssql://%(username)s:%(password)s@%(server)s:%(port)s/%(database)s' % dict(
username=username,
password=password,
server=server,
port=port,
database=database)
if not os.path.exists(SQLALCHEMY_TAR_GZ):
download_sqlalchemy_tarball()
if not os.path.exists(SQLALCHEMY_DIR):
extract_sqlalchemy_tarball()
run_sqlalchemy_tests()