diff options
Diffstat (limited to 'kpov_judge/tasks')
-rw-r--r-- | kpov_judge/tasks/copy_rename_20_files_tail_env/task.py | 43 |
1 files changed, 37 insertions, 6 deletions
diff --git a/kpov_judge/tasks/copy_rename_20_files_tail_env/task.py b/kpov_judge/tasks/copy_rename_20_files_tail_env/task.py index 856d311..44e9f87 100644 --- a/kpov_judge/tasks/copy_rename_20_files_tail_env/task.py +++ b/kpov_judge/tasks/copy_rename_20_files_tail_env/task.py @@ -107,7 +107,7 @@ params_meta = { 'wc_n_lines': {'descriptions': {'si': 'n vrstic v count.txt'}, 'w': False, 'public':False, 'type': 'integer', 'generated': True}, } -def task(IP_malishell, file_rename_dirname, mv_src_dir, mv_dst_dir, cowsay_string): +def task(IP_malishell, file_rename_dirname, mv_src_dir, mv_dst_dir, cowsay_string, curl_fname, wc_dirname): import pxssh import os # TODO: (polz) this has to be changed! Get a move on! @@ -171,10 +171,10 @@ def task(IP_malishell, file_rename_dirname, mv_src_dir, mv_dst_dir, cowsay_strin conn.prompt() results['cowsay'] = conn.before results['curl_env'] = os.environ['images'] - conn.sendline('cat {wc_dirname}/count.txt') + conn.sendline('cat {}/count.txt'.format(wc_dirname)) conn.prompt() results['wc_origfile'] = conn.before - conn.sendline('cat {wc_dirname}/lines.txt') + conn.sendline('cat {}/lines.txt'.format(wc_dirname)) conn.prompt() results['wc_lines'] = conn.before conn.logout() @@ -246,6 +246,10 @@ def task_check(results, params): results['mv_ls_size']) mv_ls_size = int(task2_re.group(1)) task2_ok = mv_ls_size < 15 and mv_ls_size > 2 + if task2_ok: + score += 1 + else: + hints += ["wrong rename size"] pre_src = set([i.strip() for i in results['pre_mv_src'].split('\n')[3:-1]]) pre_dst = set([i.strip() for i in results['pre_mv_dst'].split('\n')[3:-1]]) task2_ok = task2_ok and pre_src == set(fnames) @@ -255,9 +259,9 @@ def task_check(results, params): task2_ok = task2_ok and post_dst == set(fnames) task2_ok = task2_ok and len(post_src) < 2 if task2_ok: - score += 2 + score += 1 else: - hints += ["wrong rename cmd"] + hints += ["wrong rename files"] # mama_ukaz # task3_ok = True @@ -296,6 +300,31 @@ def task_check(results, params): #print( results['syslog_start_time']) #print( results['syslog_result']) #print( results['syslog_end_time']) + # syslog count + # TODO: check syslog + task4_ok = True + if task4_ok: + score += 1 + else: + hints += ["wrong syslog count"] + # + task5_ok = True + if int(results['curl_env'].strip()) != int(params['curl_n_images']): + task5_ok = False + if task5_ok: + score += 2 + else: + hints += ["wrong image count"] + task6_ok = True + wc_cat_str = 'cat {}/lines.txt'.format(params['wc_dirname']) + if not wc_cat_str == results['wc_lines'][:len(wc_cat_str)]: + task6_ok = False + if int(results['wc_lines'][len(wc_cat_str):].strip()) != int(params['wc_n_lines']): + task6_ok = False + if task6_ok: + score += 1 + else: + hints += ["wrong line count"] return score, hints def prepare_disks(templates, params): @@ -359,4 +388,6 @@ def prepare_disks(templates, params): lx += ['a', 'b', 'c', 'repa', 'in', 'krompir', 'raus', 'e', 'patacis'] * r.randint(50, 150) r.shuffle(lx) - d.write("{}".format(params['wc_dirname']), "".join(lx)) + d.mkdir(params['wc_dirname']) + d.chown(1000, 1000, params['wc_dirname']) + d.write("{}".format(os.path.join(params['wc_dirname'], 'count.txt')), "".join(lx)) |