Skip to content

Commit

Permalink
Merge branch 'main' into fix/datascience-notebook
Browse files Browse the repository at this point in the history
  • Loading branch information
Jakob J. Kolb committed Oct 17, 2023
2 parents 3460039 + 63156fc commit d8e6740
Show file tree
Hide file tree
Showing 3 changed files with 61 additions and 55 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/build-and-test.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ jobs:
runs-on: ubuntu-latest
strategy:
matrix:
image: ['datascience-notebook', 'python-test-environment', 'smee-proxy', 'jenkins-inbound-agent', 'toolbox']
image: ['datascience-notebook', 'python-test-environment', 'smee-proxy', 'jenkins-inbound-agent']
steps:
- name: Checkout
uses: actions/checkout@v2
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/publish.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ jobs:
runs-on: ubuntu-latest
strategy:
matrix:
image: ['datascience-notebook', 'python-test-environment', 'smee-proxy', 'jenkins-inbound-agent', 'toolbox']
image: ['datascience-notebook', 'python-test-environment', 'smee-proxy', 'jenkins-inbound-agent']
steps:
- name: Checkout
uses: actions/checkout@v2
Expand Down
112 changes: 59 additions & 53 deletions python-test-environment/python-dockerfile_test.py
Original file line number Diff line number Diff line change
@@ -1,53 +1,59 @@
import pytest
import subprocess


@pytest.mark.parametrize("container", ["python-test-environment"], indirect=["container"])
def test_jupyter(container):
assert container.status == "created"
assert container.run("poetry --version").exit_code == 0


@pytest.mark.parametrize("container", ["python-test-environment"], indirect=["container"])
def test_jupyter_git(container):
assert container.status == "created"
assert container.run("make --version").exit_code == 0


@pytest.mark.parametrize("container", ["python-test-environment"], indirect=["container"])
def test_container_has_poetry(container):
assert container.status == "created"
assert container.run("poetry --version").exit_code == 0


@pytest.mark.parametrize("container", ["python-test-environment"], indirect=["container"])
def test_can_use_poetry_in_container(container, tmp_path):
d = tmp_path / "pyproject.toml"
d.parent.rmdir()
d.parent.mkdir()
d.touch()
d.write_text(PYPROJECT_CONTENT)
# create valid pyproject.toml in container
assert container.status == "created"
subprocess.run(["docker", "cp", str(d), f"{container.id}:/home/testuser/pyproject.toml"])
print(container.run("ls -la").output)
assert container.run("poetry install").exit_code == 0


PYPROJECT_CONTENT = """
[tool.poetry]
name = "jovyan"
version = "0.1.0"
description = ""
authors = ["jakob"]
readme = "README.md"
[tool.poetry.dependencies]
python = "^3.10"
ramda = "^0.7.6"
[build-system]
requires = ["poetry-core"]
build-backend = "poetry.core.masonry.api"
"""
import pytest
import subprocess


@pytest.mark.parametrize("container", ["python-test-environment"], indirect=["container"])
def test_jupyter(container):
assert container.status == "created"
assert container.run("poetry --version").exit_code == 0


@pytest.mark.parametrize("container", ["python-test-environment"], indirect=["container"])
def test_jupyter_git(container):
assert container.status == "created"
assert container.run("make --version").exit_code == 0


@pytest.mark.parametrize("container", ["python-test-environment"], indirect=["container"])
def test_container_has_poetry(container):
assert container.status == "created"
assert container.run("poetry --version").exit_code == 0


@pytest.mark.parametrize("container", ["python-test-environment"], indirect=["container"])
def test_can_use_poetry_in_container(container, tmp_path):
d = tmp_path / "pyproject.toml"
d.parent.rmdir()
d.parent.mkdir()
d.touch()
d.write_text(PYPROJECT_CONTENT)
# create valid pyproject.toml in container
assert container.status == "created"
subprocess.run(["docker", "cp", str(d), f"{container.id}:/home/testuser/pyproject.toml"])
print(container.run("ls -la").output)
assert container.run("poetry install").exit_code == 0


@pytest.mark.parametrize("container", ["python-test-environment"], indirect=["container"])
def test_can_pyodbc_in_container(container):
assert container.status == "created"
assert container.run("echo 'import pyodbc' | python").exit_code == 0


PYPROJECT_CONTENT = """
[tool.poetry]
name = "jovyan"
version = "0.1.0"
description = ""
authors = ["jakob"]
readme = "README.md"
[tool.poetry.dependencies]
python = "^3.10"
ramda = "^0.7.6"
[build-system]
requires = ["poetry-core"]
build-backend = "poetry.core.masonry.api"
"""

0 comments on commit d8e6740

Please sign in to comment.