File: test_missing_bokeh.py

package info (click to toggle)
dask.distributed 2022.12.1%2Bds.1-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 10,164 kB
  • sloc: python: 81,938; javascript: 1,549; makefile: 228; sh: 100
file content (74 lines) | stat: -rw-r--r-- 2,932 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
from __future__ import annotations

import sys
from unittest import mock

import pytest
from packaging.version import Version
from tornado.httpclient import AsyncHTTPClient

from distributed import Scheduler
from distributed.utils_test import gen_test


@gen_test()
async def test_missing_bokeh():
    with mock.patch.dict(sys.modules, {"bokeh": None}):
        # NOTE: mocking here is fiddly; if any of these get refactored or import order
        # changes, this may break.
        sys.modules.pop("distributed.dashboard.scheduler", None)
        sys.modules.pop("distributed.dashboard.core", None)
        sys.modules.pop("distributed.dashboard.utils", None)

        async with Scheduler(dashboard_address=":0") as s:
            http_client = AsyncHTTPClient()
            response = await http_client.fetch(
                f"http://localhost:{s.http_server.port}/status"
            )
            assert response.code == 200
            body = response.body.decode()
            assert "Dask needs bokeh" in body


@gen_test()
async def test_bokeh_version_too_low():
    pytest.importorskip("bokeh")

    with mock.patch.dict(sys.modules):
        # Remove these imports, so when the scheduler imports
        # `distributed.dashboard.scheduler`, it has to re-import `dashboard.core`, which
        # is where the bokeh version detection happens at import time, via
        # `dashboard.utils.BOKEH_VERSION`.
        sys.modules.pop("distributed.dashboard.scheduler", None)
        sys.modules.pop("distributed.dashboard.core", None)

        with mock.patch("distributed.dashboard.utils.BOKEH_VERSION", Version("1.4.0")):
            with pytest.warns(UserWarning, match="1.4.0"):
                async with Scheduler(dashboard_address=":0") as s:
                    http_client = AsyncHTTPClient()
                    response = await http_client.fetch(
                        f"http://localhost:{s.http_server.port}/status"
                    )
                    assert response.code == 200
                    body = response.body.decode()
                    assert "Dask needs bokeh" in body


@gen_test()
async def test_bokeh_version_too_high():
    pytest.importorskip("bokeh")

    with mock.patch.dict(sys.modules):
        sys.modules.pop("distributed.dashboard.scheduler", None)
        sys.modules.pop("distributed.dashboard.core", None)

        with mock.patch("distributed.dashboard.utils.BOKEH_VERSION", Version("3.0.1")):
            with pytest.warns(UserWarning, match="3.0.1"):
                async with Scheduler(dashboard_address=":0") as s:
                    http_client = AsyncHTTPClient()
                    response = await http_client.fetch(
                        f"http://localhost:{s.http_server.port}/status"
                    )
                    assert response.code == 200
                    body = response.body.decode()
                    assert "Dask needs bokeh" in body