2003-06-11 22:42:40 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
## $Id$
|
|
|
|
|
|
|
|
# This tests whether the most basic mechanisms are working Also whether stderr
|
|
|
|
# output is reported correctly Also tests if water levels are working
|
|
|
|
# correctly
|
|
|
|
|
|
|
|
from boinc import *
|
|
|
|
|
2003-06-19 00:19:22 +00:00
|
|
|
class UserUC(User):
|
2003-06-11 22:42:40 +00:00
|
|
|
def __init__(self):
|
2003-06-19 00:19:22 +00:00
|
|
|
User.__init__(self)
|
|
|
|
self.project_prefs = "<project_specific>\nfoobar\n</project_specific>"
|
|
|
|
self.global_prefs = """<venue name=\"home\">
|
2003-06-11 22:42:40 +00:00
|
|
|
<work_buf_min_days>0</work_buf_min_days>
|
|
|
|
<work_buf_max_days>2</work_buf_max_days>
|
|
|
|
<disk_interval>1</disk_interval>
|
|
|
|
<run_on_batteries/>
|
|
|
|
<max_bytes_sec_down>400000</max_bytes_sec_down>
|
2003-06-18 22:11:53 +00:00
|
|
|
</venue>"""
|
2003-06-11 22:42:40 +00:00
|
|
|
|
2003-06-19 00:19:22 +00:00
|
|
|
class WorkUC(Work):
|
|
|
|
def __init__(self, redundancy=2):
|
|
|
|
Work.__init__(self)
|
|
|
|
self.wu_template = "uc_wu"
|
|
|
|
self.result_template = "uc_result"
|
|
|
|
self.redundancy = redundancy
|
|
|
|
self.delay_bound = 5*redundancy
|
|
|
|
self.input_files = ['input']
|
2003-06-11 22:42:40 +00:00
|
|
|
# Say that 1 WU takes 1 day on a ref comp
|
2003-06-19 00:19:22 +00:00
|
|
|
self.rsc_fpops = 86400*1e9/2
|
|
|
|
self.rsc_iops = 86400*1e9/2
|
|
|
|
self.rsc_disk = 10e8
|
2003-06-11 22:42:40 +00:00
|
|
|
|
2003-06-19 00:19:22 +00:00
|
|
|
class ProjectUC(Project):
|
|
|
|
def __init__(self, works=None, users=None, hosts=None,
|
|
|
|
short_name=None, long_name=None):
|
|
|
|
Project.__init__(self,
|
|
|
|
appname = 'upper_case',
|
|
|
|
works = works or [WorkUC()],
|
|
|
|
users = users or [UserUC()],
|
|
|
|
hosts = hosts,
|
|
|
|
short_name=short_name, long_name=long_name)
|
2003-06-11 22:42:40 +00:00
|
|
|
|
2003-06-19 00:19:22 +00:00
|
|
|
def validate(self):
|
|
|
|
redundancy = self.work.redundancy
|
|
|
|
Project.validate(self, redundancy)
|
2003-06-11 22:42:40 +00:00
|
|
|
result = {}
|
|
|
|
result['server_state'] = RESULT_SERVER_STATE_OVER
|
2003-06-18 22:11:53 +00:00
|
|
|
result['stderr_out'] = STARTS_WITH("""APP: upper_case: starting, argc 1
|
2003-06-11 22:42:40 +00:00
|
|
|
APP: upper_case: argv[0] is upper_case
|
2003-06-18 22:11:53 +00:00
|
|
|
APP: upper_case ending, wrote """)
|
|
|
|
# result['exit_status'] = 0
|
2003-06-19 00:19:22 +00:00
|
|
|
self.check_results(redundancy, result)
|
|
|
|
self.check_files_match("upload/uc_wu_%d_0", "uc_correct_output", count=redundancy)
|
2003-06-11 22:42:40 +00:00
|
|
|
self.assimilate()
|
|
|
|
self.file_delete()
|
2003-06-18 22:11:53 +00:00
|
|
|
self.check_deleted("download/input")
|
2003-06-19 00:19:22 +00:00
|
|
|
self.check_deleted("upload/uc_wu_%d_0", count=redundancy)
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
self.install()
|
|
|
|
self.install_feeder()
|
|
|
|
self.start_servers()
|
2003-06-11 22:42:40 +00:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
test_msg("standard upper_case application");
|
|
|
|
|
|
|
|
project = ProjectUC()
|
2003-06-19 00:19:22 +00:00
|
|
|
project.run()
|
|
|
|
project.host.run()
|
|
|
|
project.validate()
|
|
|
|
project.stop()
|