ray/test/runtest.py

299 lines
11 KiB
Python
Raw Normal View History

2016-02-22 13:55:06 -08:00
import unittest
import halo
import halo.serialization as serialization
import halo.services as services
import halo.worker as worker
2016-02-22 13:55:06 -08:00
import numpy as np
import time
2016-03-01 01:02:08 -08:00
import subprocess32 as subprocess
import os
from google.protobuf.text_format import *
2016-02-22 13:55:06 -08:00
import halo_pb2
2016-02-22 13:55:06 -08:00
import types_pb2
import test_functions
import halo.arrays.remote as ra
import halo.arrays.distributed as da
2016-03-10 12:35:31 -08:00
class SerializationTest(unittest.TestCase):
def roundTripTest(self, worker, data):
serialized, _ = serialization.serialize(worker.handle, data)
result = serialization.deserialize(worker.handle, serialized)
2016-03-10 12:35:31 -08:00
self.assertEqual(data, result)
def numpyTypeTest(self, worker, typ):
a = np.random.randint(0, 10, size=(100, 100)).astype(typ)
b, _ = serialization.serialize(worker.handle, a)
c = serialization.deserialize(worker.handle, b)
self.assertTrue((a == c).all())
2016-03-10 12:35:31 -08:00
def testSerialize(self):
[w] = services.start_singlenode_cluster(return_drivers=True)
2016-03-10 12:35:31 -08:00
self.roundTripTest(w, [1, "hello", 3.0])
self.roundTripTest(w, 42)
self.roundTripTest(w, "hello world")
self.roundTripTest(w, 42.0)
self.roundTripTest(w, (1.0, "hi"))
2016-06-03 12:11:30 -07:00
self.roundTripTest(w, None)
self.roundTripTest(w, (None, None))
self.roundTripTest(w, ("hello", None))
2016-06-03 12:21:16 -07:00
self.roundTripTest(w, True)
self.roundTripTest(w, False)
self.roundTripTest(w, (True, False))
self.roundTripTest(w, {True: "hello", False: "world"})
self.roundTripTest(w, {"hello" : "world", 1: 42, 1.0: 45})
self.roundTripTest(w, {})
2016-03-24 23:35:38 -07:00
2016-03-10 12:35:31 -08:00
a = np.zeros((100, 100))
res, _ = serialization.serialize(w.handle, a)
b = serialization.deserialize(w.handle, res)
2016-03-10 12:35:31 -08:00
self.assertTrue((a == b).all())
2016-03-08 16:14:02 -08:00
self.numpyTypeTest(w, 'int8')
self.numpyTypeTest(w, 'uint8')
# self.numpyTypeTest('int16') # TODO(pcm): implement this
# self.numpyTypeTest('int32') # TODO(pcm): implement this
self.numpyTypeTest(w, 'float32')
self.numpyTypeTest(w, 'float64')
ref0 = halo.push(0, w)
ref1 = halo.push(0, w)
ref2 = halo.push(0, w)
ref3 = halo.push(0, w)
a = np.array([[ref0, ref1], [ref2, ref3]])
capsule, _ = serialization.serialize(w.handle, a)
result = serialization.deserialize(w.handle, capsule)
self.assertTrue((a == result).all())
services.cleanup()
2016-03-12 15:25:45 -08:00
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
2016-02-22 13:55:06 -08:00
def testObjStore(self):
[w1, w2] = services.start_singlenode_cluster(return_drivers=True, num_objstores=2, num_workers_per_objstore=0)
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 = halo.push(data, w1)
result = halo.pull(objref, w1)
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, [1, 2, 3, "a", (1, 2)], ("a", ("b", 3))]:
objref = worker.push(data, w1)
result = worker.pull(objref, w2)
self.assertEqual(result, data)
# pushing an array, shipping it to another worker, and pulling it shouldn't change it
for data in [np.zeros([10, 20]), np.random.normal(size=[45, 25])]:
objref = worker.push(data, w1)
result = worker.pull(objref, w2)
self.assertTrue(np.alltrue(result == data))
"""
# pulling multiple times shouldn't matter
for data in [np.zeros([10, 20]), np.random.normal(size=[45, 25]), np.zeros([10, 20], dtype=np.dtype("float64")), np.zeros([10, 20], dtype=np.dtype("float32")), np.zeros([10, 20], dtype=np.dtype("int64")), np.zeros([10, 20], dtype=np.dtype("int32"))]:
objref = worker.push(data, w1)
result = worker.pull(objref, w2)
result = worker.pull(objref, w2)
result = worker.pull(objref, w2)
self.assertTrue(np.alltrue(result == data))
"""
# shipping a numpy array inside something else should be fine
data = ("a", np.random.normal(size=[10, 10]))
objref = worker.push(data, w1)
result = worker.pull(objref, w2)
self.assertTrue(data[0] == result[0])
self.assertTrue(np.alltrue(data[1] == result[1]))
# shipping a numpy array inside something else should be fine
data = ["a", np.random.normal(size=[10, 10])]
objref = worker.push(data, w1)
result = worker.pull(objref, w2)
self.assertTrue(data[0] == result[0])
self.assertTrue(np.alltrue(data[1] == result[1]))
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-05-26 16:33:30 -07:00
def testRemoteTask(self):
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")
[w] = services.start_singlenode_cluster(return_drivers=True, num_workers_per_objstore=1, worker_path=test_path)
2016-02-22 13:55:06 -08:00
2016-03-10 14:40:46 -08:00
value_before = "test_string"
2016-05-26 16:33:30 -07:00
objref = w.submit_task("test_functions.print_string", [value_before])
2016-03-10 14:40:46 -08:00
time.sleep(0.2)
value_after = halo.pull(objref[0], w)
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
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):
[w] = services.start_singlenode_cluster(return_drivers=True)
2016-03-10 14:40:46 -08:00
for i in range(100):
value_before = i * 10 ** 6
objref = halo.push(value_before, w)
value_after = halo.pull(objref, w)
2016-03-10 14:40:46 -08:00
self.assertEqual(value_before, value_after)
for i in range(100):
value_before = i * 10 ** 6 * 1.0
objref = halo.push(value_before, w)
value_after = halo.pull(objref, w)
2016-03-10 14:40:46 -08:00
self.assertEqual(value_before, value_after)
for i in range(100):
value_before = "h" * i
objref = halo.push(value_before, w)
value_after = halo.pull(objref, w)
2016-03-10 14:40:46 -08:00
self.assertEqual(value_before, value_after)
for i in range(100):
value_before = [1] * i
objref = halo.push(value_before, w)
value_after = halo.pull(objref, w)
2016-03-10 14:40:46 -08:00
self.assertEqual(value_before, value_after)
services.cleanup()
2016-04-05 00:34:23 -07:00
class APITest(unittest.TestCase):
def testObjRefAliasing(self):
test_dir = os.path.dirname(os.path.abspath(__file__))
test_path = os.path.join(test_dir, "testrecv.py")
[w] = services.start_singlenode_cluster(return_drivers=True, num_workers_per_objstore=3, worker_path=test_path)
2016-05-26 16:33:30 -07:00
objref = w.submit_task("test_functions.test_alias_f", [])
self.assertTrue(np.alltrue(halo.pull(objref[0], w) == np.ones([3, 4, 5])))
2016-05-26 16:33:30 -07:00
objref = w.submit_task("test_functions.test_alias_g", [])
self.assertTrue(np.alltrue(halo.pull(objref[0], w) == np.ones([3, 4, 5])))
2016-05-26 16:33:30 -07:00
objref = w.submit_task("test_functions.test_alias_h", [])
self.assertTrue(np.alltrue(halo.pull(objref[0], w) == np.ones([3, 4, 5])))
2016-04-05 00:34:23 -07:00
services.cleanup()
2016-06-03 00:10:17 -07:00
def testKeywordArgs(self):
test_dir = os.path.dirname(os.path.abspath(__file__))
test_path = os.path.join(test_dir, "testrecv.py")
services.start_singlenode_cluster(return_drivers=False, num_workers_per_objstore=1, worker_path=test_path)
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct1(1)
self.assertEqual(halo.pull(x), "1 hello")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct1(1, "hi")
self.assertEqual(halo.pull(x), "1 hi")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct1(1, b="world")
self.assertEqual(halo.pull(x), "1 world")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct2(a="w", b="hi")
self.assertEqual(halo.pull(x), "w hi")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct2(b="hi", a="w")
self.assertEqual(halo.pull(x), "w hi")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct2(a="w")
self.assertEqual(halo.pull(x), "w world")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct2(b="hi")
self.assertEqual(halo.pull(x), "hello hi")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct2("w")
self.assertEqual(halo.pull(x), "w world")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct2("w", "hi")
self.assertEqual(halo.pull(x), "w hi")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct3(0, 1, c="w", d="hi")
self.assertEqual(halo.pull(x), "0 1 w hi")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct3(0, 1, d="hi", c="w")
self.assertEqual(halo.pull(x), "0 1 w hi")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct3(0, 1, c="w")
self.assertEqual(halo.pull(x), "0 1 w world")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct3(0, 1, d="hi")
self.assertEqual(halo.pull(x), "0 1 hello hi")
2016-06-03 00:10:17 -07:00
x = test_functions.keyword_fct3(0, 1)
self.assertEqual(halo.pull(x), "0 1 hello world")
2016-06-03 00:10:17 -07:00
services.cleanup()
def testVariableNumberOfArgs(self):
test_dir = os.path.dirname(os.path.abspath(__file__))
test_path = os.path.join(test_dir, "testrecv.py")
services.start_singlenode_cluster(return_drivers=False, num_workers_per_objstore=1, worker_path=test_path)
x = test_functions.varargs_fct1(0, 1, 2)
self.assertEqual(halo.pull(x), "0 1 2")
x = test_functions.varargs_fct2(0, 1, 2)
self.assertEqual(halo.pull(x), "1 2")
self.assertTrue(test_functions.kwargs_exception_thrown)
self.assertTrue(test_functions.varargs_and_kwargs_exception_thrown)
services.cleanup()
class ReferenceCountingTest(unittest.TestCase):
def testDeallocation(self):
test_dir = os.path.dirname(os.path.abspath(__file__))
test_path = os.path.join(test_dir, "testrecv.py")
services.start_singlenode_cluster(return_drivers=False, num_workers_per_objstore=3, worker_path=test_path)
x = test_functions.test_alias_f()
halo.pull(x)
time.sleep(0.1)
objref_val = x.val
self.assertTrue(halo.scheduler_info()["reference_counts"][objref_val] == 1)
del x
self.assertTrue(halo.scheduler_info()["reference_counts"][objref_val] == -1) # -1 indicates deallocated
y = test_functions.test_alias_h()
halo.pull(y)
time.sleep(0.1)
objref_val = y.val
self.assertTrue(halo.scheduler_info()["reference_counts"][objref_val:(objref_val + 3)] == [1, 0, 0])
del y
self.assertTrue(halo.scheduler_info()["reference_counts"][objref_val:(objref_val + 3)] == [-1, -1, -1])
z = da.zeros([da.BLOCK_SIZE, 2 * da.BLOCK_SIZE], "float")
time.sleep(0.1)
objref_val = z.val
self.assertTrue(halo.scheduler_info()["reference_counts"][objref_val:(objref_val + 3)] == [1, 1, 1])
del z
time.sleep(0.1)
self.assertTrue(halo.scheduler_info()["reference_counts"][objref_val:(objref_val + 3)] == [-1, -1, -1])
x = ra.zeros([10, 10], "float")
y = ra.zeros([10, 10], "float")
z = ra.dot(x, y)
objref_val = x.val
time.sleep(0.1)
self.assertTrue(halo.scheduler_info()["reference_counts"][objref_val:(objref_val + 3)] == [1, 1, 1])
del x
time.sleep(0.1)
self.assertTrue(halo.scheduler_info()["reference_counts"][objref_val:(objref_val + 3)] == [-1, 1, 1])
del y
time.sleep(0.1)
self.assertTrue(halo.scheduler_info()["reference_counts"][objref_val:(objref_val + 3)] == [-1, -1, 1])
del z
time.sleep(0.1)
self.assertTrue(halo.scheduler_info()["reference_counts"][objref_val:(objref_val + 3)] == [-1, -1, -1])
services.cleanup()
2016-02-22 13:55:06 -08:00
if __name__ == '__main__':
unittest.main()