Skip to content

Commit

Permalink
parameterize mysql_address in tests, allow passing one or more addres…
Browse files Browse the repository at this point in the history
…ses via pytest args (#693)
  • Loading branch information
Nothing4You authored Jan 28, 2022
1 parent b515859 commit 2955052
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 4 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ jobs:
run: |
# timeout ensures a more or less clean stop by sending a KeyboardInterrupt which will still provide useful logs
timeout --preserve-status --signal=INT --verbose 5m \
pytest --color=yes --capture=no --verbosity 2 --cov-report term --cov-report xml --cov aiomysql ./tests
pytest --color=yes --capture=no --verbosity 2 --cov-report term --cov-report xml --cov aiomysql ./tests --mysql-address "tcp-${{ join(matrix.db, '') }}=127.0.0.1:3306"
env:
PYTHONUNBUFFERED: 1
DB: '${{ matrix.db[0] }}'
Expand Down
50 changes: 47 additions & 3 deletions tests/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,41 @@ def pytest_generate_tests(metafunc):
loop_type = ['asyncio', 'uvloop'] if uvloop else ['asyncio']
metafunc.parametrize("loop_type", loop_type)

if "mysql_address" in metafunc.fixturenames:
mysql_addresses = []
ids = []

opt_mysql_address = list(metafunc.config.getoption("mysql_address"))
for i in range(len(opt_mysql_address)):
if "=" in opt_mysql_address[i]:
label, addr = opt_mysql_address[i].split("=", 1)
ids.append(label)
else:
addr = opt_mysql_address[i]
ids.append("tcp{}".format(i))

if ":" in addr:
addr = addr.split(":", 1)
mysql_addresses.append((addr[0], int(addr[1])))
else:
mysql_addresses.append((addr, 3306))

# default to connecting to localhost
if len(mysql_addresses) == 0:
mysql_addresses = [("127.0.0.1", 3306)]
ids = ["tcp-local"]

assert len(mysql_addresses) == len(set(mysql_addresses)), \
"mysql targets are not unique"
assert len(ids) == len(set(ids)), \
"mysql target names are not unique"

metafunc.parametrize("mysql_address",
mysql_addresses,
ids=ids,
scope="session",
)


# This is here unless someone fixes the generate_tests bit
@pytest.fixture(scope='session')
Expand Down Expand Up @@ -101,6 +136,15 @@ def pytest_configure(config):
)


def pytest_addoption(parser):
parser.addoption(
"--mysql-address",
action="append",
default=[],
help="list of addresses to connect to: [name=]host[:port]",
)


@pytest.fixture
def mysql_params(mysql_server):
params = {**mysql_server['conn_params'],
Expand Down Expand Up @@ -205,7 +249,7 @@ def ensure_mysql_version(request, mysql_image, mysql_tag):


@pytest.fixture(scope='session')
def mysql_server(mysql_image, mysql_tag):
def mysql_server(mysql_image, mysql_tag, mysql_address):
ssl_directory = os.path.join(os.path.dirname(__file__),
'ssl_resources', 'ssl')
ca_file = os.path.join(ssl_directory, 'ca.pem')
Expand All @@ -216,8 +260,8 @@ def mysql_server(mysql_image, mysql_tag):
# ctx.verify_mode = ssl.CERT_NONE

server_params = {
'host': '127.0.0.1',
'port': 3306,
'host': mysql_address[0],
'port': mysql_address[1],
'user': 'root',
'password': os.environ.get("MYSQL_ROOT_PASSWORD"),
'ssl': ctx,
Expand Down

0 comments on commit 2955052

Please sign in to comment.