diff options
Diffstat (limited to 'kpov_judge/tasks/mock_entrance_exam')
-rw-r--r-- | kpov_judge/tasks/mock_entrance_exam/task.py | 24 |
1 files changed, 12 insertions, 12 deletions
diff --git a/kpov_judge/tasks/mock_entrance_exam/task.py b/kpov_judge/tasks/mock_entrance_exam/task.py index 52772a3..a6e3c8c 100644 --- a/kpov_judge/tasks/mock_entrance_exam/task.py +++ b/kpov_judge/tasks/mock_entrance_exam/task.py @@ -8,7 +8,7 @@ # - switch to a real SSH/SFTP client to properly handle filenames instructions = { - 'si': u''' + 'si': ''' Postavite dva navidezna računalnika - SimpleArbiter in Student. Oba naj bosta povezana na internet. Poleg tega mora biti Student na naslovu {student_IP} dostopen s SimpleArbiter. @@ -28,7 +28,7 @@ Napišite skripto ali program {P_script} v domačem imeniku uporabnika student, Lastnik vseh ustvarjenih datotek mora biti uporabnik student. Gesla uporabnika student (vaje) ne smete spreminjati.''', - 'en': u'''Set up two virtual machines - SimpleArbiter and Student. + 'en': '''Set up two virtual machines - SimpleArbiter and Student. Both should be connected to the Internet. Student should also be accessible from SimpleArbiter at the address {student_IP}. @@ -142,10 +142,10 @@ def task(student_IP, net_prog_name, conn.login(student_IP, 'student', 'vaje') results = dict() r = random.Random(int(param_gen_seed)) - env_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in xrange(11)]) + env_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in range(11)]) - arg_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in xrange(13)]) - stdin_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in xrange(17)]) + arg_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in range(13)]) + stdin_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in range(17)]) conn.sendline('ls -l {}'.format(P_script)) conn.prompt() results['script_ls'] = conn.before @@ -175,8 +175,8 @@ def gen_params(user_id, params_meta): r = random.Random(user_id+'evil cornholio') params = kpov_random_helpers.default_gen(user_id, params_meta) homedir = '/home/student/' - params['env_c'] = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ') for i in xrange(5)]) - params['P_c'] = "".join([r.choice('abcdefghijklmnoprst') for i in xrange(5)]) + ".c" + params['env_c'] = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ') for i in range(5)]) + params['P_c'] = "".join([r.choice('abcdefghijklmnoprst') for i in range(5)]) + ".c" params['param_gen_seed'] = str(r.randint(0, 2**24)) params['c_destroy_gen_seed'] = str(r.randint(0, 2**24)) dest_net = kpov_random_helpers.IPv4_subnet_gen(r, '10.0.2.128/26', 26) @@ -193,7 +193,7 @@ def task_check(results, params): r = 0 arg_len = len(arg) env_len = len(var) - for i in xrange(100): + for i in range(100): s_out += chr(32 + ((ord(arg[i % arg_len]) ^ ord(var[i % env_len])) % 64)) r += ord(arg[i % arg_len]) + ord(var[i % env_len]) + i; if (i % 17 == 0): @@ -210,9 +210,9 @@ def task_check(results, params): score = 0 hints = [] r = random.Random(int(params['param_gen_seed'])) - env_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in xrange(11)]) - arg_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in xrange(13)]) - stdin_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in xrange(17)]) + env_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in range(11)]) + arg_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in range(13)]) + stdin_val = "".join([r.choice('ABCDEFGHIJKLMNPRSTUVZ012345') for i in range(17)]) expected_script_stdout, expected_script_stderr, rval = test_out_gen( params['arg_c'], env_val ) @@ -315,7 +315,7 @@ done; sh_path = r.choice(['/usr/share/doc', '/var/lib', '/usr/local/share', '/etc/alternatives']) sh_file = sh_path + '/' + task_params['net_prog_name'] d.write(sh_file, evil_shell_source) - d.chmod(0775, sh_file) + d.chmod(0o775, sh_file) d.write("/etc/rc.local", """#!/bin/sh -e export PATH=$PATH:{} nohup {} & |