mirror of
https://github.com/jupyterhub/the-littlest-jupyterhub.git
synced 2025-12-18 21:54:05 +08:00
Merge remote-tracking branch 'upstream/main' into conda-channels
This commit is contained in:
@@ -1,30 +1,28 @@
|
||||
"""
|
||||
Test simplest plugin
|
||||
Test the plugin in integration-tests/plugins/simplest that makes use of all tljh
|
||||
recognized plugin hooks that are defined in tljh/hooks.py.
|
||||
"""
|
||||
from ruamel.yaml import YAML
|
||||
import requests
|
||||
import os
|
||||
import subprocess
|
||||
|
||||
from tljh.config import CONFIG_FILE, USER_ENV_PREFIX, HUB_ENV_PREFIX
|
||||
from tljh import user
|
||||
from ruamel.yaml import YAML
|
||||
|
||||
from tljh import user
|
||||
from tljh.config import CONFIG_FILE, HUB_ENV_PREFIX, USER_ENV_PREFIX
|
||||
|
||||
GIT_REPO_PATH = os.path.abspath(os.path.dirname(os.path.dirname(__file__)))
|
||||
yaml = YAML(typ="rt")
|
||||
|
||||
|
||||
def test_apt_packages():
|
||||
"""
|
||||
Test extra apt packages are installed
|
||||
"""
|
||||
assert os.path.exists("/usr/games/sl")
|
||||
def test_tljh_extra_user_conda_packages():
|
||||
subprocess.check_call([f"{USER_ENV_PREFIX}/bin/python3", "-c", "import tqdm"])
|
||||
|
||||
|
||||
def test_pip_packages():
|
||||
"""
|
||||
Test extra user & hub pip packages are installed
|
||||
"""
|
||||
def test_tljh_extra_user_pip_packages():
|
||||
subprocess.check_call([f"{USER_ENV_PREFIX}/bin/python3", "-c", "import django"])
|
||||
|
||||
|
||||
def test_tljh_extra_hub_pip_packages():
|
||||
subprocess.check_call([f"{HUB_ENV_PREFIX}/bin/python3", "-c", "import there"])
|
||||
|
||||
|
||||
@@ -35,45 +33,60 @@ def test_conda_packages():
|
||||
subprocess.check_call([f"{USER_ENV_PREFIX}/bin/python3", "-c", "import hypothesis"])
|
||||
subprocess.check_call([f"{USER_ENV_PREFIX}/bin/csvtk", "cat", "--help"])
|
||||
|
||||
def test_tljh_extra_apt_packages():
|
||||
assert os.path.exists("/usr/games/sl")
|
||||
|
||||
def test_config_hook():
|
||||
|
||||
def test_tljh_custom_jupyterhub_config():
|
||||
"""
|
||||
Check config changes are present
|
||||
Test that the provided tljh_custom_jupyterhub_config hook has made the tljh
|
||||
jupyterhub load additional jupyterhub config.
|
||||
"""
|
||||
tljh_jupyterhub_config = os.path.join(GIT_REPO_PATH, "tljh", "jupyterhub_config.py")
|
||||
output = subprocess.check_output(
|
||||
[
|
||||
f"{HUB_ENV_PREFIX}/bin/python3",
|
||||
"-m",
|
||||
"jupyterhub",
|
||||
"--show-config",
|
||||
"--config",
|
||||
tljh_jupyterhub_config,
|
||||
],
|
||||
text=True,
|
||||
)
|
||||
assert "jupyterhub_config_set_by_simplest_plugin" in output
|
||||
|
||||
|
||||
def test_tljh_config_post_install():
|
||||
"""
|
||||
Test that the provided tljh_config_post_install hook has made tljh recognize
|
||||
additional tljh config.
|
||||
"""
|
||||
with open(CONFIG_FILE) as f:
|
||||
data = yaml.load(f)
|
||||
|
||||
assert data["simplest_plugin"]["present"]
|
||||
tljh_config = yaml.load(f)
|
||||
assert tljh_config["Test"]["tljh_config_set_by_simplest_plugin"]
|
||||
|
||||
|
||||
def test_jupyterhub_config_hook():
|
||||
def test_tljh_post_install():
|
||||
"""
|
||||
Test that tmpauthenticator is enabled by our custom config plugin
|
||||
Test that the provided tljh_post_install hook has been executed by looking
|
||||
for a specific file written.
|
||||
"""
|
||||
resp = requests.get("http://localhost/hub/tmplogin", allow_redirects=False)
|
||||
assert resp.status_code == 302
|
||||
assert resp.headers["Location"] == "/hub/spawn"
|
||||
|
||||
|
||||
def test_post_install_hook():
|
||||
"""
|
||||
Test that the test_post_install file has the correct content
|
||||
"""
|
||||
with open("test_post_install") as f:
|
||||
with open("test_tljh_post_install") as f:
|
||||
content = f.read()
|
||||
|
||||
assert content == "123456789"
|
||||
assert "file_written_by_simplest_plugin" in content
|
||||
|
||||
|
||||
def test_new_user_create():
|
||||
def test_tljh_new_user_create():
|
||||
"""
|
||||
Test that plugin receives username as arg
|
||||
Test that the provided tljh_new_user_create hook has been executed by
|
||||
looking for a specific file written.
|
||||
"""
|
||||
# Trigger the hook by letting tljh's code create a user
|
||||
username = "user1"
|
||||
# Call ensure_user to make sure the user plugin gets called
|
||||
user.ensure_user(username)
|
||||
|
||||
with open("test_new_user_create") as f:
|
||||
content = f.read()
|
||||
|
||||
assert content == username
|
||||
assert "file_written_by_simplest_plugin" in content
|
||||
assert username in content
|
||||
|
||||
Reference in New Issue
Block a user