mirror of
https://github.com/vale981/ray
synced 2025-03-08 19:41:38 -05:00

* Revert "Make tests more informative (#372)" This reverts commitfd353250c8
. * fix bugs, in particular deactivate worker service on driver and remove condition variables * changes to minimize the changes in this PR * switch from faulty mutex synchronization to using atomics * Increase the default size of the message queues, to accommodate exporting large numbers of remote functions. This is a temporary fix, but not a long term solution. * Reorganize the scheduler export code to queue up exports. This does not solve the underlying problem yet, but sets up a solution. * Start a separate thread on driver to print error messages by constantly querying the scheduler. This is a temporary solution because the solution based on starting a worker service for the driver which the scheduler can push error messages to is buggy. * Fix segfault in taskcapsule destructor. * Move tests for catching errors into a separate test file. * Revert "roll back grpc (#368)" This reverts commitc01ef95d04
.
83 lines
3.2 KiB
Python
83 lines
3.2 KiB
Python
import unittest
|
|
import ray
|
|
import time
|
|
import os
|
|
import numpy as np
|
|
|
|
import test_functions
|
|
|
|
class MicroBenchmarkTest(unittest.TestCase):
|
|
|
|
def testTiming(self):
|
|
reload(test_functions)
|
|
ray.init(start_ray_local=True, num_workers=3)
|
|
|
|
# measure the time required to submit a remote task to the scheduler
|
|
elapsed_times = []
|
|
for _ in range(1000):
|
|
start_time = time.time()
|
|
test_functions.empty_function.remote()
|
|
end_time = time.time()
|
|
elapsed_times.append(end_time - start_time)
|
|
elapsed_times = np.sort(elapsed_times)
|
|
average_elapsed_time = sum(elapsed_times) / 1000
|
|
print "Time required to submit an empty function call:"
|
|
print " Average: {}".format(average_elapsed_time)
|
|
print " 90th percentile: {}".format(elapsed_times[900])
|
|
print " 99th percentile: {}".format(elapsed_times[990])
|
|
print " worst: {}".format(elapsed_times[999])
|
|
# average_elapsed_time should be about 0.00038
|
|
|
|
# measure the time required to submit a remote task to the scheduler (where the remote task returns one value)
|
|
elapsed_times = []
|
|
for _ in range(1000):
|
|
start_time = time.time()
|
|
test_functions.trivial_function.remote()
|
|
end_time = time.time()
|
|
elapsed_times.append(end_time - start_time)
|
|
elapsed_times = np.sort(elapsed_times)
|
|
average_elapsed_time = sum(elapsed_times) / 1000
|
|
print "Time required to submit a trivial function call:"
|
|
print " Average: {}".format(average_elapsed_time)
|
|
print " 90th percentile: {}".format(elapsed_times[900])
|
|
print " 99th percentile: {}".format(elapsed_times[990])
|
|
print " worst: {}".format(elapsed_times[999])
|
|
# average_elapsed_time should be about 0.001
|
|
|
|
# measure the time required to submit a remote task to the scheduler and get the result
|
|
elapsed_times = []
|
|
for _ in range(1000):
|
|
start_time = time.time()
|
|
x = test_functions.trivial_function.remote()
|
|
ray.get(x)
|
|
end_time = time.time()
|
|
elapsed_times.append(end_time - start_time)
|
|
elapsed_times = np.sort(elapsed_times)
|
|
average_elapsed_time = sum(elapsed_times) / 1000
|
|
print "Time required to submit a trivial function call and get the result:"
|
|
print " Average: {}".format(average_elapsed_time)
|
|
print " 90th percentile: {}".format(elapsed_times[900])
|
|
print " 99th percentile: {}".format(elapsed_times[990])
|
|
print " worst: {}".format(elapsed_times[999])
|
|
# average_elapsed_time should be about 0.0013
|
|
|
|
# measure the time required to do do a put
|
|
elapsed_times = []
|
|
for _ in range(1000):
|
|
start_time = time.time()
|
|
ray.put(1)
|
|
end_time = time.time()
|
|
elapsed_times.append(end_time - start_time)
|
|
elapsed_times = np.sort(elapsed_times)
|
|
average_elapsed_time = sum(elapsed_times) / 1000
|
|
print "Time required to put an int:"
|
|
print " Average: {}".format(average_elapsed_time)
|
|
print " 90th percentile: {}".format(elapsed_times[900])
|
|
print " 99th percentile: {}".format(elapsed_times[990])
|
|
print " worst: {}".format(elapsed_times[999])
|
|
# average_elapsed_time should be about 0.00087
|
|
|
|
ray.worker.cleanup()
|
|
|
|
if __name__ == "__main__":
|
|
unittest.main(verbosity=2)
|