X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/245c6abec4bf824ad8c8683e59ab6ee08c836cf7..487dc40959c4a7a8838624c6e108236320e79c8d:/sdk/python/tests/test_websockets.py diff --git a/sdk/python/tests/test_websockets.py b/sdk/python/tests/test_websockets.py index fe065e1f2b..45dd28a157 100644 --- a/sdk/python/tests/test_websockets.py +++ b/sdk/python/tests/test_websockets.py @@ -1,60 +1,36 @@ +import Queue import run_test_server import unittest import arvados import arvados.events -import time import threading -class WebsocketTest(run_test_server.TestCaseWithServers): - MAIN_SERVER = {'websockets': True} - - def on_event(self, ev): - if self.state == 1: - self.assertEqual(200, ev['status']) - self.state = 2 - elif self.state == 2: - self.assertEqual(self.h[u'uuid'], ev[u'object_uuid']) - self.state = 3 - self.done.set() - elif self.state == 3: - self.fail() - +class EventTestBase(object): def runTest(self): - self.state = 1 - self.done = threading.Event() - run_test_server.authorize_with("admin") - api = arvados.api('v1', cache=False) - ws = arvados.events.subscribe(api, [['object_uuid', 'is_a', 'arvados#human']], self.on_event) - time.sleep(1) - self.h = api.humans().create(body={}).execute() - self.done.wait(10) - self.assertEqual(3, self.state) - ws.close() - -class PollClientTest(run_test_server.TestCaseWithServers): - MAIN_SERVER = {} - - def on_event(self, ev): - if self.state == 1: - self.assertEqual(200, ev['status']) - self.state = 2 - elif self.state == 2: - self.assertEqual(self.h[u'uuid'], ev[u'object_uuid']) - self.state = 3 - self.done.set() - elif self.state == 3: - self.fail() + events = Queue.Queue(3) + self.ws = arvados.events.subscribe( + arvados.api('v1'), [['object_uuid', 'is_a', 'arvados#human']], + events.put, poll_fallback=2) + self.assertIsInstance(self.ws, self.WS_TYPE) + self.assertEqual(200, events.get(True, 10)['status']) + human = arvados.api('v1').humans().create(body={}).execute() + self.assertEqual(human['uuid'], events.get(True, 10)['object_uuid']) + self.assertTrue(events.empty(), "got more events than expected") + + def tearDown(self): + try: + self.ws.close() + except AttributeError: + pass + super(EventTestBase, self).tearDown() + + +class WebsocketTest(EventTestBase, run_test_server.TestCaseWithServers): + MAIN_SERVER = {'websockets': True} + WS_TYPE = arvados.events.EventClient - def runTest(self): - self.state = 1 - self.done = threading.Event() - run_test_server.authorize_with("admin") - api = arvados.api('v1', cache=False) - ws = arvados.events.subscribe(api, [['object_uuid', 'is_a', 'arvados#human']], self.on_event, poll_fallback=2) - time.sleep(1) - self.h = api.humans().create(body={}).execute() - self.done.wait(10) - self.assertEqual(3, self.state) - ws.close() +class PollClientTest(EventTestBase, run_test_server.TestCaseWithServers): + MAIN_SERVER = {} + WS_TYPE = arvados.events.PollClient