Skip to content

Commit

Permalink
Make test function readily-REPL-available (#1712)
Browse files Browse the repository at this point in the history
Having written this function multiple times, then pulling it out of the tests
fixtures while poking at the engines, recognize that it's perhaps a REPL-useful
utility.  Documentation for the dev inline, while the core is still used by the
test fixtures.
  • Loading branch information
khk-globus committed Nov 14, 2024
1 parent 638f8a6 commit 8bcd355
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 11 deletions.
14 changes: 3 additions & 11 deletions compute_endpoint/tests/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,14 @@
import globus_sdk
import pytest
import responses
from globus_compute_common import messagepack
from globus_compute_endpoint import engines
from globus_compute_endpoint.engines.base import GlobusComputeEngineBase
from globus_compute_sdk.sdk.web_client import WebClient
from globus_compute_sdk.serialize import ComputeSerializer
from parsl.launchers import SimpleLauncher
from parsl.providers import LocalProvider
from tests.utils import ez_pack_function

from .utils import create_task_packer


@pytest.fixture(autouse=True)
Expand Down Expand Up @@ -215,15 +215,7 @@ def serde():

@pytest.fixture
def ez_pack_task(serde, task_uuid, container_uuid):
def _pack_it(fn, *a, **k) -> bytes:
task_body = ez_pack_function(serde, fn, a, k)
return messagepack.pack(
messagepack.message_types.Task(
task_id=task_uuid, container_id=container_uuid, task_buffer=task_body
)
)

return _pack_it
return create_task_packer(serde, task_uuid, container_uuid)


@pytest.fixture
Expand Down
46 changes: 46 additions & 0 deletions compute_endpoint/tests/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@
import time
import types
import typing as t
import uuid

from globus_compute_common import messagepack
from globus_compute_sdk.serialize import ComputeSerializer


def create_traceback(start: int = 0) -> types.TracebackType:
Expand Down Expand Up @@ -88,6 +92,48 @@ def ez_pack_function(serializer, func, args, kwargs):
)


def create_task_packer(
serde: ComputeSerializer | None = None,
task_uuid: uuid.UUID | None = None,
container_uuid: uuid.UUID | None = None,
) -> t.Callable[[t.Callable, ...], bytes]:
"""
A quick go-to for easier development while hacking on the engine submit routines.
Reminder for the dev:
>>> import uuid
>>> from tests.utils import create_task_packer
>>> from globus_compute_common import messagepack
>>> from globus_compute_sdk.serialize import ComputeSerializer
>>> from globus_compute_endpoint.engines import ThreadPoolEngine
>>>
>>> def some_func(*a, **k):
... return f"[args=<{a}>, k=<{k}>]"
...
>>> pack_task = create_task_packer()
>>> task_bytes = pack_task(some_func)
>>>
>>> e = ThreadPoolEngine()
>>> e.start(endpoint_id=uuid.uuid4())
>>> encoded_result = e.submit("some_task_id", task_bytes, {}).result()
>>> result = messagepack.unpack(encoded_result)
>>> payload = serde.deserialize(result.data)
"""
serde = serde or ComputeSerializer()
task_uuid = task_uuid or uuid.uuid4()

def _pack_it(fn, *a, **k) -> bytes:
task_body = ez_pack_function(serde, fn, a, k)
return messagepack.pack(
messagepack.message_types.Task(
task_id=task_uuid, container_id=container_uuid, task_buffer=task_body
)
)

return _pack_it


def double(x: int) -> int:
return x * 2

Expand Down

0 comments on commit 8bcd355

Please sign in to comment.