xref: /sqlalchemy/tox.ini (revision c658540b)
16b051503SMike Bayer
29281e700SMike Bayer[tox]
3c312b3b2SMike Bayerenvlist = py
49281e700SMike Bayer
59281e700SMike Bayer[testenv]
649dfeda6SMike Bayer# note that we have a .coveragerc file that points coverage specifically
749dfeda6SMike Bayer# at ./lib/sqlalchemy, and *not* at the build that tox might create under .tox.
849dfeda6SMike Bayer# See the notes below for setenv for more detail.
949dfeda6SMike Bayer# also using --cov-append so that we can aggregate multiple runs together.
1049dfeda6SMike Bayer# Jenkins etc. need to call "coverage erase" externally.
1149dfeda6SMike Bayercov_args=--cov=sqlalchemy --cov-report term --cov-append --cov-report xml --exclude-tag memory-intensive --exclude-tag timing-intensive -k "not aaa_profiling"
1249dfeda6SMike Bayer
13f704f47aSMike Bayerinstall_command=python -m pip install {env:TOX_PIP_OPTS:} {opts} {packages}
1422800000SMike Bayer
15086ad9ceSMike Bayerusedevelop=
16086ad9ceSMike Bayer     cov: True
17d100bfcfSMike Bayer
18664290abSMike Bayerdeps=pytest!=3.9.1,!=3.9.2
193568e508SMike Bayer     pytest-xdist
200396fb76SMike Bayer     mock; python_version < '3.3'
21d1fe8f43SMike Bayer
22d1fe8f43SMike Bayer     # psycopg2 minimum 2.7 needed only for correct profiling results
2366e483ebSMike Bayer     postgresql: psycopg2>=2.7
2426564407SMike Bayer
25d1fe8f43SMike Bayer     # mysqlclient minimum 1.4.0 needed only for correct profiling results
26d1fe8f43SMike Bayer     py3{,5,6,7,8,9,10,11}-mysql: mysqlclient>=1.4.0
27d1fe8f43SMike Bayer     py2{,7}-mysql: mysqlclient>=1.4.0,<2
28d1fe8f43SMike Bayer
298d1579ccSMike Bayer     mysql: pymysql
3083750628SMike Bayer     mysql: mysql-connector-python
31d1fe8f43SMike Bayer
32d1fe8f43SMike Bayer     py3{,5,6,7,8,9,10,11}-oracle: cx_oracle>=7.0
33d1fe8f43SMike Bayer     py2{,7}-oracle: cx_oracle>=7.0,<8
34d1fe8f43SMike Bayer
358d1579ccSMike Bayer     mssql: pyodbc
36d1fe8f43SMike Bayer
37d100bfcfSMike Bayer     cov: pytest-cov
389281e700SMike Bayer
3949dfeda6SMike Bayerwhitelist_externals=sh
4049dfeda6SMike Bayer
4149dfeda6SMike Bayer# PYTHONPATH - erased so that we use the build that's present
4249dfeda6SMike Bayer# in .tox as the SQLAlchemy library to be imported
4349dfeda6SMike Bayer#
4449dfeda6SMike Bayer# PYTHONUSERSITE - this *MUST* be set so that the ./lib/ import
4549dfeda6SMike Bayer# set up explicitly in test/conftest.py is *disabled*, again so that
4649dfeda6SMike Bayer# when SQLAlchemy is built into the .tox area, we use that and not the
4749dfeda6SMike Bayer# local checkout, at least when usedevelop=False
4849dfeda6SMike Bayer#
4949dfeda6SMike Bayer# BASECOMMAND - using an env variable here so we can use it
5049dfeda6SMike Bayer# as a substitution in a command (see https://bitbucket.org/hpk42/tox/issues/307/)
5149dfeda6SMike Bayer#
52ffb6fbf8SMike Bayer# only use --dropfirst option if we're *not* using -n;
53ffb6fbf8SMike Bayer# if -n is used, we're working in brand new DBs anyway, dropfirst
54ffb6fbf8SMike Bayer# will collide on CI environments
55f30e35baSMike Bayersetenv=
56f30e35baSMike Bayer    PYTHONPATH=
5749dfeda6SMike Bayer    PYTHONNOUSERSITE=1
5800309662SMike Bayer    BASECOMMAND=python -m pytest --log-info=sqlalchemy.testing
59086ad9ceSMike Bayer
603ceb87daSMike Bayer    WORKERS={env:TOX_WORKERS:-n4  --max-worker-restart=5}
61d1fe8f43SMike Bayer    oracle: WORKERS={env:TOX_WORKERS:-n2  --max-worker-restart=5}
62086ad9ceSMike Bayer    nocext: DISABLE_SQLALCHEMY_CEXT=1
63a54a0c6eSMike Bayer    cext: REQUIRE_SQLALCHEMY_CEXT=1
64086ad9ceSMike Bayer    cov: COVERAGE={[testenv]cov_args}
659e6393c6SMike Bayer    sqlite: SQLITE={env:TOX_SQLITE:--db sqlite}
6679a53645SGord Thompson    sqlite_file: SQLITE={env:TOX_SQLITE_FILE:--db sqlite_file}
679e6393c6SMike Bayer    postgresql: POSTGRESQL={env:TOX_POSTGRESQL:--db postgresql}
689e6393c6SMike Bayer    mysql: MYSQL={env:TOX_MYSQL:--db mysql --db pymysql}
69d1fe8f43SMike Bayer    oracle: ORACLE={env:TOX_ORACLE:--db oracle}
70f87570acSMike Bayer    mssql: MSSQL={env:TOX_MSSQL:--db mssql}
7179a53645SGord Thompson    oracle,mssql,sqlite_file: IDENTS=--write-idents db_idents.txt
7279a53645SGord Thompson    oracle,mssql,sqlite_file: NOMEMORY=--nomemory
73086ad9ceSMike Bayer    backendonly: BACKENDONLY=--backend-only
74f30e35baSMike Bayer
757f423e87SMike Bayer# tox as of 2.0 blocks all environment variables from the
767f423e87SMike Bayer# outside, unless they are here (or in TOX_TESTENV_PASSENV,
77077f26afSMike Bayer# wildcards OK).  Need at least these
7879a53645SGord Thompsonpassenv=ORACLE_HOME NLS_LANG TOX_POSTGRESQL TOX_MYSQL TOX_ORACLE TOX_MSSQL TOX_SQLITE TOX_SQLITE_FILE TOX_WORKERS
797f423e87SMike Bayer
8049dfeda6SMike Bayer# for nocext, we rm *.so in lib in case we are doing usedevelop=True
819281e700SMike Bayercommands=
82c312b3b2SMike Bayer  cext: /bin/true
832efd89d0SMike Bayer  nocext: sh -c "rm -f lib/sqlalchemy/*.so"
842efd89d0SMike Bayer  {env:BASECOMMAND} {env:WORKERS} {env:SQLITE:} {env:POSTGRESQL:} {env:MYSQL:} {env:ORACLE:} {env:MSSQL:} {env:BACKENDONLY:} {env:IDENTS:} {env:NOMEMORY:} {env:COVERAGE:} {posargs}
8579a53645SGord Thompson  oracle,mssql,sqlite_file: python reap_dbs.py db_idents.txt
869281e700SMike Bayer
87d229360aSMike Bayer# thanks to https://julien.danjou.info/the-best-flake8-extensions/
889281e700SMike Bayer[testenv:pep8]
89b9d9d416SMike Bayerbasepython = python3.7
90d229360aSMike Bayerdeps=
91d229360aSMike Bayer      flake8
92d229360aSMike Bayer      flake8-import-order
93d229360aSMike Bayer      flake8-builtins
94d229360aSMike Bayer      flake8-docstrings
95d229360aSMike Bayer      flake8-rst-docstrings
961a9f5754SMike Bayer      pydocstyle<4.0.0
97d229360aSMike Bayer      # used by flake8-rst-docstrings
98d229360aSMike Bayer      pygments
99d8378f45SFederico Caselli      black==19.10b0
100d8378f45SFederico Casellicommands =
101d8378f45SFederico Caselli     flake8 ./lib/ ./test/ ./examples/ setup.py doc/build/conf.py
102d8378f45SFederico Caselli     black --check .
103c658540bSFederico Caselli
104c658540bSFederico Caselli# command run in the github action when cext are active.
105c658540bSFederico Caselli[testenv:github-cext]
106c658540bSFederico Casellicommands=
107c658540bSFederico Caselli  python -m pytest {env:WORKERS} {env:SQLITE:} {env:POSTGRESQL:} {env:MYSQL:} {env:ORACLE:} {env:MSSQL:} {env:BACKENDONLY:} {env:IDENTS:} {env:NOMEMORY:} {env:COVERAGE:} {posargs}
108c658540bSFederico Caselli  oracle,mssql,sqlite_file: python reap_dbs.py db_idents.txt
109c658540bSFederico Caselli
110c658540bSFederico Caselli# command run in the github action when cext are not active.
111c658540bSFederico Caselli[testenv:github-nocext]
112c658540bSFederico Casellicommands=
113c658540bSFederico Caselli  python -m pytest {env:WORKERS} {env:SQLITE:} {env:POSTGRESQL:} {env:MYSQL:} {env:ORACLE:} {env:MSSQL:} {env:BACKENDONLY:} {env:IDENTS:} {env:NOMEMORY:} {env:COVERAGE:} {posargs}
114c658540bSFederico Caselli  oracle,mssql,sqlite_file: python reap_dbs.py db_idents.txt