Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
30 changes: 29 additions & 1 deletion torchx/specs/test/api_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,12 @@
# pyre-strict

import asyncio
import concurrent
import os
import time
import unittest
from dataclasses import asdict
from typing import Dict, List, Mapping, Union
from typing import Dict, List, Mapping, Tuple, Union
from unittest.mock import MagicMock

import torchx.specs.named_resources_aws as named_resources_aws
Expand Down Expand Up @@ -299,6 +300,33 @@ async def update(value: str, time_seconds: int) -> str:
self.assertEqual("base", default.image)
self.assertEqual("nentry", default.entrypoint)

def test_concurrent_override_role(self) -> None:

def delay(value: Tuple[str, str], time_seconds: int) -> Tuple[str, str]:
time.sleep(time_seconds)
return value

with concurrent.futures.ThreadPoolExecutor(max_workers=1) as executor:
launcher_fbpkg_future: concurrent.futures.Future = executor.submit(
delay, ("value1", "value2"), 2
)

def get_image() -> str:
concurrent.futures.wait([launcher_fbpkg_future], 3)
return launcher_fbpkg_future.result()[0]

def get_entrypoint() -> str:
concurrent.futures.wait([launcher_fbpkg_future], 3)
return launcher_fbpkg_future.result()[1]

default = Role(
"foobar",
"torch",
overrides={"image": get_image, "entrypoint": get_entrypoint},
)
self.assertEqual("value1", default.image)
self.assertEqual("value2", default.entrypoint)


class AppHandleTest(unittest.TestCase):
def test_parse_malformed_app_handles(self) -> None:
Expand Down
Loading