Skip to content

Commit

Permalink
Make for_code a public property in all strategies
Browse files Browse the repository at this point in the history
This is in order to enable non-test code to use the property.
  • Loading branch information
chris-janidlo committed Dec 18, 2024
1 parent cc7589c commit 721c8d2
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 17 deletions.
11 changes: 5 additions & 6 deletions compute_sdk/globus_compute_sdk/serialize/base.py
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
from abc import ABCMeta, abstractmethod
import typing as t
from abc import ABC, abstractmethod

from globus_compute_sdk.errors import DeserializationError

# 2 unique characters and a newline
IDENTIFIER_LENGTH = 3


class SerializationStrategy(metaclass=ABCMeta):
class SerializationStrategy(ABC):
"""A SerializationStrategy is in charge of converting function source code or
arguments into string data and back again.
"""
Expand All @@ -16,10 +17,8 @@ def __init_subclass__(cls):
if len(cls.identifier) != IDENTIFIER_LENGTH:
raise ValueError(f"Identifiers must be {IDENTIFIER_LENGTH} characters long")

@property
@abstractmethod
def identifier(self):
pass
identifier: t.ClassVar[str]
for_code: t.ClassVar[bool]

def chomp(self, payload: str) -> str:
"""If the payload starts with the identifier, return the remaining block
Expand Down
14 changes: 7 additions & 7 deletions compute_sdk/globus_compute_sdk/serialize/concretes.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@

class DillDataBase64(SerializationStrategy):
identifier = "00\n"
_for_code = False
for_code = False

def __init__(self):
super().__init__()
Expand All @@ -34,7 +34,7 @@ def deserialize(self, payload: str):

class JSONData(SerializationStrategy):
identifier = "11\n"
_for_code = False
for_code = False

def __init__(self):
super().__init__()
Expand All @@ -59,7 +59,7 @@ class DillCodeSource(SerializationStrategy):
"""

identifier = "04\n"
_for_code = True
for_code = True

def __init__(self):
super().__init__()
Expand Down Expand Up @@ -89,7 +89,7 @@ class DillCodeTextInspect(SerializationStrategy):
"""

identifier = "03\n"
_for_code = True
for_code = True

def __init__(self):
super().__init__()
Expand Down Expand Up @@ -119,7 +119,7 @@ class PickleCode(SerializationStrategy):
"""

identifier = "02\n"
_for_code = True
for_code = True

def __init__(self):
super().__init__()
Expand All @@ -145,7 +145,7 @@ class DillCode(SerializationStrategy):
"""

identifier = "01\n"
_for_code = True
for_code = True

def __init__(self):
super().__init__()
Expand All @@ -171,7 +171,7 @@ class CombinedCode(SerializationStrategy):
"""

identifier = "10\n"
_for_code = True
for_code = True

# Functions are serialized using the following strategies and the resulting encoded
# versions are stored as chunks. Allows redundancy if one of the strategies fails
Expand Down
9 changes: 6 additions & 3 deletions compute_sdk/tests/integration/test_serialization.py
Original file line number Diff line number Diff line change
Expand Up @@ -327,7 +327,7 @@ def test_compute_serializer_defaults():

@pytest.mark.parametrize("strategy", concretes.SELECTABLE_STRATEGIES)
def test_selectable_serialization(strategy):
if strategy._for_code:
if strategy.for_code:
serializer = ComputeSerializer(strategy_code=strategy())
data = foo
else:
Expand All @@ -340,6 +340,7 @@ def test_selectable_serialization(strategy):
def test_serializer_errors_on_unknown_strategy():
class NewStrategy(SerializationStrategy):
identifier = "aa\n"
for_code = True

def serialize(self, data):
pass
Expand All @@ -352,15 +353,17 @@ def deserialize(self, payload):
with pytest.raises(SerializationError):
ComputeSerializer(strategy_code=strategy)

NewStrategy.for_code = False

with pytest.raises(SerializationError):
ComputeSerializer(strategy_data=strategy)


@pytest.mark.parametrize(
"strategy_code", (s for s in concretes.SELECTABLE_STRATEGIES if s._for_code)
"strategy_code", (s for s in concretes.SELECTABLE_STRATEGIES if s.for_code)
)
@pytest.mark.parametrize(
"strategy_data", (s for s in concretes.SELECTABLE_STRATEGIES if not s._for_code)
"strategy_data", (s for s in concretes.SELECTABLE_STRATEGIES if not s.for_code)
)
@pytest.mark.parametrize(
"function, args, kwargs",
Expand Down
2 changes: 1 addition & 1 deletion compute_sdk/tests/unit/test_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -211,7 +211,7 @@ def test_batch_created_websocket_queue(gcc, create_result_queue):


@pytest.mark.parametrize(
"strategy", [s for s in SELECTABLE_STRATEGIES if not s._for_code]
"strategy", [s for s in SELECTABLE_STRATEGIES if not s.for_code]
)
def test_batch_respects_serialization_strategy(gcc, strategy):
gcc.fx_serializer = ComputeSerializer(strategy_data=strategy())
Expand Down

0 comments on commit 721c8d2

Please sign in to comment.