ray/test/runtest.py

226 lines
7 KiB
Python
Raw Normal View History

2016-02-22 13:55:06 -08:00
import unittest
import orchpy
2016-02-22 13:55:06 -08:00
import orchpy.services as services
import orchpy.worker as worker
import numpy as np
import time
2016-03-01 01:02:08 -08:00
import subprocess32 as subprocess
import os
2016-03-12 15:25:45 -08:00
import arrays.single as single
2016-03-01 01:02:08 -08:00
from google.protobuf.text_format import *
2016-02-22 13:55:06 -08:00
from grpc.beta import implementations
import orchestra_pb2
import types_pb2
2016-03-08 16:14:02 -08:00
IP_ADDRESS = "127.0.0.1"
2016-02-22 13:55:06 -08:00
TIMEOUT_SECONDS = 5
2016-03-01 01:02:08 -08:00
def connect_to_scheduler(host, port):
channel = implementations.insecure_channel(host, port)
2016-03-02 15:23:11 -08:00
return orchestra_pb2.beta_create_Scheduler_stub(channel)
2016-03-01 01:02:08 -08:00
def connect_to_objstore(host, port):
channel = implementations.insecure_channel(host, port)
return orchestra_pb2.beta_create_ObjStore_stub(channel)
2016-03-08 16:14:02 -08:00
def address(host, port):
return host + ":" + str(port)
scheduler_port_counter = 0
def new_scheduler_port():
global scheduler_port_counter
scheduler_port_counter += 1
return 10000 + scheduler_port_counter
worker_port_counter = 0
def new_worker_port():
global worker_port_counter
worker_port_counter += 1
return 40000 + worker_port_counter
objstore_port_counter = 0
def new_objstore_port():
global objstore_port_counter
objstore_port_counter += 1
return 20000 + objstore_port_counter
2016-03-10 12:35:31 -08:00
class SerializationTest(unittest.TestCase):
def roundTripTest(self, data):
serialized = orchpy.lib.serialize_object(data)
result = orchpy.lib.deserialize_object(serialized)
self.assertEqual(data, result)
def testSerialize(self):
data = [1, "hello", 3.0]
self.roundTripTest(data)
a = np.zeros((100, 100))
res = orchpy.lib.serialize_object(a)
b = orchpy.lib.deserialize_object(res)
self.assertTrue((a == b).all())
2016-03-08 16:14:02 -08:00
class OrchPyLibTest(unittest.TestCase):
def testOrchPyLib(self):
scheduler_port = new_scheduler_port()
objstore_port = new_objstore_port()
worker_port = new_worker_port()
services.start_scheduler(address(IP_ADDRESS, scheduler_port))
time.sleep(0.1)
services.start_objstore(address(IP_ADDRESS, scheduler_port), address(IP_ADDRESS, objstore_port))
time.sleep(0.2)
w = worker.Worker()
worker.connect(address(IP_ADDRESS, scheduler_port), address(IP_ADDRESS, objstore_port), address(IP_ADDRESS, worker_port), w)
w.put_object(orchpy.lib.ObjRef(0), 'hello world')
result = w.get_object(orchpy.lib.ObjRef(0))
self.assertEqual(result, 'hello world')
2016-03-12 15:25:45 -08:00
services.cleanup()
2016-02-22 13:55:06 -08:00
class ObjStoreTest(unittest.TestCase):
"""Test setting up object stores, transfering data between them and retrieving data to a client"""
def testObjStore(self):
2016-03-08 16:14:02 -08:00
scheduler_port = new_scheduler_port()
objstore1_port = new_objstore_port()
objstore2_port = new_objstore_port()
worker1_port = new_worker_port()
worker2_port = new_worker_port()
2016-03-10 14:40:46 -08:00
services.start_scheduler(address(IP_ADDRESS, scheduler_port))
time.sleep(0.1)
services.start_objstore(address(IP_ADDRESS, scheduler_port), address(IP_ADDRESS, objstore1_port))
services.start_objstore(address(IP_ADDRESS, scheduler_port), address(IP_ADDRESS, objstore2_port))
2016-02-22 13:55:06 -08:00
2016-03-01 01:02:08 -08:00
time.sleep(0.2)
2016-02-22 13:55:06 -08:00
2016-03-08 16:14:02 -08:00
scheduler_stub = connect_to_scheduler(IP_ADDRESS, scheduler_port)
objstore1_stub = connect_to_objstore(IP_ADDRESS, objstore1_port)
objstore2_stub = connect_to_objstore(IP_ADDRESS, objstore2_port)
2016-02-22 13:55:06 -08:00
2016-03-01 01:02:08 -08:00
worker1 = worker.Worker()
worker.connect(address(IP_ADDRESS, scheduler_port), address(IP_ADDRESS, objstore1_port), address(IP_ADDRESS, worker1_port), worker1)
2016-02-22 13:55:06 -08:00
2016-03-01 01:02:08 -08:00
worker2 = worker.Worker()
worker.connect(address(IP_ADDRESS, scheduler_port), address(IP_ADDRESS, objstore2_port), address(IP_ADDRESS, worker2_port), worker2)
2016-02-22 13:55:06 -08:00
2016-03-09 11:40:36 -08:00
# pushing and pulling an object shouldn't change it
for data in ["h", "h" * 10000, 0, 0.0]:
objref = worker.push(data, worker1)
result = worker.pull(objref, worker1)
2016-03-09 11:40:36 -08:00
self.assertEqual(result, data)
# pushing an object, shipping it to another worker, and pulling it shouldn't change it
for data in ["h", "h" * 10000, 0, 0.0]:
objref = worker.push(data, worker1)
response = objstore1_stub.DeliverObj(orchestra_pb2.DeliverObjRequest(objref=objref.val, objstore_address=address(IP_ADDRESS, objstore2_port)), TIMEOUT_SECONDS)
result = worker.pull(objref, worker2)
2016-03-09 11:40:36 -08:00
self.assertEqual(result, data)
2016-02-22 13:55:06 -08:00
2016-03-01 01:02:08 -08:00
services.cleanup()
2016-02-22 13:55:06 -08:00
class SchedulerTest(unittest.TestCase):
2016-03-01 01:02:08 -08:00
def testCall(self):
2016-03-08 16:14:02 -08:00
scheduler_port = new_scheduler_port()
objstore_port = new_objstore_port()
worker1_port = new_worker_port()
worker2_port = new_worker_port()
2016-03-10 14:40:46 -08:00
services.start_scheduler(address(IP_ADDRESS, scheduler_port))
time.sleep(0.1)
services.start_objstore(address(IP_ADDRESS, scheduler_port), address(IP_ADDRESS, objstore_port))
2016-02-22 13:55:06 -08:00
2016-03-01 01:02:08 -08:00
time.sleep(0.2)
2016-02-22 13:55:06 -08:00
2016-03-08 16:14:02 -08:00
scheduler_stub = connect_to_scheduler(IP_ADDRESS, scheduler_port)
objstore_stub = connect_to_objstore(IP_ADDRESS, objstore_port)
2016-02-22 13:55:06 -08:00
2016-03-01 01:02:08 -08:00
time.sleep(0.2)
2016-02-22 13:55:06 -08:00
2016-03-08 16:14:02 -08:00
worker1 = worker.Worker()
worker.connect(address(IP_ADDRESS, scheduler_port), address(IP_ADDRESS, objstore_port), address(IP_ADDRESS, worker1_port), worker1)
2016-02-22 13:55:06 -08:00
2016-03-09 11:40:36 -08:00
test_dir = os.path.dirname(os.path.abspath(__file__))
test_path = os.path.join(test_dir, "testrecv.py")
2016-03-10 14:40:46 -08:00
services.start_worker(test_path, address(IP_ADDRESS, scheduler_port), address(IP_ADDRESS, objstore_port), address(IP_ADDRESS, worker2_port))
2016-02-22 13:55:06 -08:00
2016-03-09 11:40:36 -08:00
time.sleep(0.2)
2016-02-22 13:55:06 -08:00
2016-03-10 14:40:46 -08:00
value_before = "test_string"
objref = worker1.remote_call("__main__.print_string", [value_before])
time.sleep(0.2)
value_after = worker.pull(objref[0], worker1)
self.assertEqual(value_before, value_after)
2016-02-22 13:55:06 -08:00
2016-03-01 01:02:08 -08:00
time.sleep(0.1)
2016-02-22 13:55:06 -08:00
reply = scheduler_stub.SchedulerDebugInfo(orchestra_pb2.SchedulerDebugInfoRequest(), TIMEOUT_SECONDS)
2016-02-22 13:55:06 -08:00
2016-03-09 11:40:36 -08:00
services.cleanup()
2016-02-22 13:55:06 -08:00
2016-03-10 14:40:46 -08:00
class WorkerTest(unittest.TestCase):
def testPushPull(self):
scheduler_port = new_scheduler_port()
objstore_port = new_objstore_port()
worker1_port = new_worker_port()
services.start_scheduler(address(IP_ADDRESS, scheduler_port))
time.sleep(0.1)
services.start_objstore(address(IP_ADDRESS, scheduler_port), address(IP_ADDRESS, objstore_port))
2016-03-10 14:40:46 -08:00
time.sleep(0.2)
worker1 = worker.Worker()
worker.connect(address(IP_ADDRESS, scheduler_port), address(IP_ADDRESS, objstore_port), address(IP_ADDRESS, worker1_port), worker1)
for i in range(100):
value_before = i * 10 ** 6
objref = worker.push(value_before, worker1)
value_after = worker.pull(objref, worker1)
self.assertEqual(value_before, value_after)
for i in range(100):
value_before = i * 10 ** 6 * 1.0
objref = worker.push(value_before, worker1)
value_after = worker.pull(objref, worker1)
self.assertEqual(value_before, value_after)
for i in range(100):
value_before = "h" * i
objref = worker.push(value_before, worker1)
value_after = worker.pull(objref, worker1)
self.assertEqual(value_before, value_after)
for i in range(100):
value_before = [1] * i
objref = worker.push(value_before, worker1)
value_after = worker.pull(objref, worker1)
self.assertEqual(value_before, value_after)
services.cleanup()
2016-02-22 13:55:06 -08:00
if __name__ == '__main__':
unittest.main()