Skip to content

Commit

Permalink
Opt out of docker tests
Browse files Browse the repository at this point in the history
Otherwise, fail if docker not installed or container not built, with
helpful error message
  • Loading branch information
pvandyken committed Oct 18, 2023
1 parent 2c7474f commit a7bab82
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 25 deletions.
7 changes: 6 additions & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -113,13 +113,18 @@ expr = "platform.python_version()"

[tool.poe.tasks.build-container]
args = [{ name = "container_id", positional = true, required = true }]
uses = { VERSION = "_get_version"}
uses = { VERSION = "_get_version" }
cmd = """
docker build 'containers/${container_id}' \
--tag 'snakebids/${container_id}:${VERSION}' \
--build-arg="PYTHON_VERSION=${VERSION}"
"""

[tool.pytest.ini_options]
markers = [
"docker: marks tests as requiring docker (deselect with '-m \"not docker\"')",
]

[tool.isort]
profile = "black"
multi_line_output = 3
Expand Down
59 changes: 35 additions & 24 deletions snakebids/tests/helpers.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@

import functools as ft
import itertools as it
import re
import subprocess as sp
from datetime import timedelta
from pathlib import Path
Expand All @@ -21,7 +22,7 @@
import more_itertools as itx
import pytest
from hypothesis import HealthCheck, example, settings
from typing_extensions import ParamSpec, TypeAlias
from typing_extensions import ParamSpec

from snakebids import bids
from snakebids.core.datasets import BidsDataset
Expand All @@ -31,7 +32,7 @@

_T = TypeVar("_T")
_T_contra = TypeVar("_T_contra", contravariant=True)
_F = TypeVar("_F", bound="Callable[..., Any]")
_P = ParamSpec("_P")


def get_zip_list(
Expand Down Expand Up @@ -127,10 +128,6 @@ def __eq__(self, other: object) -> bool:
return True


_P = ParamSpec("_P")
_FuncT: TypeAlias = Callable[_P, _T]


def debug(**overrides: Any):
"""Disable a hypothesis decorated test with specific parameter examples
Expand All @@ -139,7 +136,7 @@ def debug(**overrides: Any):
when hypothesis is not being used)
"""

def inner(func: _FuncT[_P, _T]) -> _FuncT[_P, _T]:
def inner(func: Callable[_P, _T]) -> Callable[_P, _T]:
if not hasattr(func, "hypothesis"):
raise TypeError(f"{func} is not decorated with hypothesis.given")

Expand Down Expand Up @@ -268,22 +265,36 @@ def expand_zip_list(


def needs_docker(container: str):
def inner(func: _F) -> _F:
try:
sp.run(["docker"], check=True)
except sp.CalledProcessError:
return pytest.mark.skip(reason="docker is not available on this machine")(
func
)
try:
sp.run(["docker", "image", "inspect", container], check=True)
except sp.CalledProcessError:
return pytest.mark.skip(reason=f"{container} is not built on this machine")(
func
)
return func

return inner
def decorator(func: Callable[_P, _T]) -> Callable[_P, _T]:
@pytest.mark.docker
@ft.wraps(func)
def wrapper(*args: _P.args, **kwargs: _P.kwargs):
try:
sp.run(["docker"], check=True)
except (sp.CalledProcessError, FileNotFoundError):
pytest.fail(
"docker is not available on this machine. To skip docker tests, "
"use '-m \"not docker\"'"
)
try:
sp.run(["docker", "image", "inspect", container], check=True)
except sp.CalledProcessError:
if not (match := re.match(r"snakebids/([\w\-])\:", container)):
pytest.fail(
f"Unrecognized docker image: {container}. Should be "
"'snakebids/{container_id}:{version}"
)
container_id = match[1]
pytest.fail(
f"{container} is not built on this machine. To build container, "
f"run `poetry run poe build-container {container_id}`. To skip "
"docker tests, use '-m \"not docker\"'"
)
return func(*args, **kwargs)

return wrapper

return decorator


def entity_to_wildcard(entities: str | Iterable[str], /):
Expand All @@ -296,7 +307,7 @@ def identity(obj: _T) -> _T:


def example_if(condition: bool, *args: Any, **kwargs: Any):
def inner(func: _FuncT[_P, _T]) -> _FuncT[_P, _T]:
def inner(func: Callable[_P, _T]) -> Callable[_P, _T]:
return example(*args, **kwargs)(func)

if condition:
Expand Down

0 comments on commit a7bab82

Please sign in to comment.