From 0d45ae47238808ac4659a81c7dc94aba88c810f5 Mon Sep 17 00:00:00 2001 From: Martin Date: Tue, 22 Sep 2015 10:37:24 +0200 Subject: Added first two problems of Lists and For section. --- .../problems/lists_and_for/contains_42/common.py | 97 ++++++++++++++++++++++ 1 file changed, 97 insertions(+) create mode 100644 python/problems/lists_and_for/contains_42/common.py (limited to 'python/problems/lists_and_for/contains_42/common.py') diff --git a/python/problems/lists_and_for/contains_42/common.py b/python/problems/lists_and_for/contains_42/common.py new file mode 100644 index 0000000..3a5a905 --- /dev/null +++ b/python/problems/lists_and_for/contains_42/common.py @@ -0,0 +1,97 @@ +# coding=utf-8 + +import re +from python.util import has_token_sequence, string_almost_equal, \ + string_contains_number, get_tokens, get_numbers, get_exception_desc +from server.hints import Hint, HintSequence + +id = 193 +group = 'lists_and_for' +number = 1 +visible = True + +solution = '''\ +xs = [42, 5, 4, -7, 2, 12, -3, -4, 11, 42, 2] + +vsebuje = False +for x in xs: + if x == 42: + vsebuje = True +print(vsebuje) +''' + +hint_type = { + 'plan': HintSequence('plan', 1), + 'no_xs': Hint('no_xs'), + 'for_loop': Hint('for_loop'), + 'if_clause': Hint('if_clause'), + 'printing': Hint('printing'), + 'print_out_for': Hint('print_out_for') +} + +def test(python, code): + test_xs = [[42, 5, 4, -7, 2, 12, -3, -4, 11, 42, 2], + [42, 5, 4, -7, 2, 12, -3, -4, 11, 2], + [5, 4, -7, 2, 12, -3, -4, 11, 2], + [], + [42], + [1, 2, 3, -42], + [1, 2, 3, 42]] + test_out = [ + True, + True, + False, + False, + True, + False, + True + ] + + n_correct = 0 + for xs_i, xs in enumerate(test_xs): + # change code to contain new xs instead of the one + # given by user + tcode = re.sub(r'^xs\s*=\s*\[.*?\]', + 'xs = ' + str(xs), + code, + flags = re.DOTALL | re.MULTILINE) + + # use python session to call tcode + answers = python(code=tcode, inputs=[(None, None)], timeout=1.0) + output = answers[0][1] + + if str(test_out[xs_i]) in output and \ + str(not test_out[xs_i]) not in output: + n_correct += 1 + return n_correct, len(test_out) + +def hint(python, code): + # run one test first to see if there are any exceptions + answer = python(code=code, inputs=[(None, None)], timeout=1.0) + exc = get_exception_desc(answer) + if exc: return exc + + tokens = get_tokens(code) + + # if has no xs, tell him to ask for values + if not has_token_sequence(tokens, ['xs', '=', '[']): + return [{'id' : 'no_xs'}] + + # student does not have while or for: instruct him on loops + if not has_token_sequence(tokens, ['while']) and \ + not has_token_sequence(tokens, ['for']): + return [{'id' : 'for_loop'}] + + if not has_token_sequence(tokens, ['if']): + return [{'id' : 'if_clause'}] + + # student is not using print function + if not has_token_sequence(tokens, ['print']): + return [{'id' : 'printing'}] + + # student is not using print at the beginning of line + if not has_token_sequence(tokens, ['\n', 'print']): + return [{'id' : 'print_out_for'}] + + + return None -- cgit v1.2.1