2003-06-19 02:01:18 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
## $Id$
|
|
|
|
|
|
|
|
# End to end test. Tests make_work, feeder, scheduling server, client,
|
2003-08-15 23:04:36 +00:00
|
|
|
# file_upload_handler, validator, assimilator, transitioner, and file_deleter
|
2003-06-19 02:01:18 +00:00
|
|
|
# on a large batch of workunits. Confirms that credit is correctly granted
|
|
|
|
# and that unneeded files are deleted
|
|
|
|
|
|
|
|
from test_uc import *
|
|
|
|
import time, os
|
|
|
|
|
|
|
|
class ProjectBackend(ProjectUC):
|
2003-08-16 01:02:49 +00:00
|
|
|
def __init__(self, num_wu, redundancy):
|
2003-08-15 23:04:36 +00:00
|
|
|
self.num_wu = num_wu
|
|
|
|
ProjectUC.__init__(self, redundancy = redundancy, short_name = 'test_backend')
|
2003-08-15 23:22:30 +00:00
|
|
|
|
|
|
|
def run(self):
|
2003-08-16 01:02:49 +00:00
|
|
|
self.install()
|
2003-08-15 23:22:30 +00:00
|
|
|
|
2003-08-16 01:04:11 +00:00
|
|
|
self.sched_install('make_work', max_wus = self.num_wu)
|
2003-06-26 00:20:44 +00:00
|
|
|
self.sched_install('assimilator')
|
|
|
|
self.sched_install('file_deleter')
|
|
|
|
self.sched_install('validate_test')
|
|
|
|
self.sched_install('feeder')
|
2003-08-15 23:04:36 +00:00
|
|
|
self.sched_install('transitioner')
|
2003-06-19 02:01:18 +00:00
|
|
|
self.start_servers()
|
|
|
|
|
2003-08-16 01:02:49 +00:00
|
|
|
db = self.db_open()
|
|
|
|
while True:
|
|
|
|
wus_assimilated = num_wus_assimilated(db)
|
|
|
|
verbose_echo(1, "Running: WUs [%dassim/%dtotal/%dtarget] Results: [%dunsent,%dinProg,%dover/%d]" % (
|
|
|
|
wus_assimilated, num_wus(db), num_wu,
|
|
|
|
num_results_unsent(db),
|
|
|
|
num_results_in_progress(db),
|
|
|
|
num_results_over(db),
|
|
|
|
num_results(db)))
|
|
|
|
if wus_assimilated >= num_wu:
|
|
|
|
break
|
|
|
|
time.sleep(.1)
|
|
|
|
db.close()
|
|
|
|
|
2003-06-19 02:01:18 +00:00
|
|
|
def check(self):
|
2003-08-16 01:02:49 +00:00
|
|
|
self.check_results(ResultUC(), self.num_wu*redundancy)
|
2003-06-19 02:01:18 +00:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2003-08-15 23:04:36 +00:00
|
|
|
num_wu = sys.argv[1:] and get_int(sys.argv[1]) or 100
|
|
|
|
redundancy = sys.argv[2:] and get_int(sys.argv[2]) or 5
|
2003-08-16 01:02:49 +00:00
|
|
|
test_msg("entire backend (with %d workunits * %d results each)" % (num_wu, redundancy));
|
2003-08-15 23:04:36 +00:00
|
|
|
ProjectBackend(num_wu = num_wu, redundancy = redundancy)
|
2003-06-24 21:06:32 +00:00
|
|
|
run_check_all()
|