summaryrefslogtreecommitdiff
path: root/python/problems/introduction/fast_fingers
diff options
context:
space:
mode:
authorMartin <martin@leo.fri1.uni-lj.si>2015-09-24 12:39:32 +0200
committerMartin <martin@leo.fri1.uni-lj.si>2015-09-24 12:39:32 +0200
commit898789199e6af91dfa900650c22df6d26f7e635f (patch)
tree6ed40a66659d9e2815247e3ef2d0955b0dafee29 /python/problems/introduction/fast_fingers
parent21853cef10ad1ce4c90ca22c6184c7e5077740e2 (diff)
Finished the first version of introduction section.
Diffstat (limited to 'python/problems/introduction/fast_fingers')
-rw-r--r--python/problems/introduction/fast_fingers/common.py72
-rw-r--r--python/problems/introduction/fast_fingers/sl.py89
2 files changed, 89 insertions, 72 deletions
diff --git a/python/problems/introduction/fast_fingers/common.py b/python/problems/introduction/fast_fingers/common.py
index 8ab51ab..cda6486 100644
--- a/python/problems/introduction/fast_fingers/common.py
+++ b/python/problems/introduction/fast_fingers/common.py
@@ -1,11 +1,12 @@
# coding=utf-8
-from python.util import has_token_sequence
+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 = 190
group = 'introduction'
-number = 2
+number = 5
visible = True
solution = '''\
@@ -14,28 +15,62 @@ zacetek = time()
rezultat = float(input("Koliko je 7*6? "))
konec = time()
cas = konec­zacetek
-print ("Porabil si ", cas, "s.")
+print ("Vpisal si ", rezultat, ". Za razmišljanje si porabil ", cas, " s.")
'''
hint_type = {
- 'plan': Hint('plan'),
- 'name_error': HintSequence('name_error', 4),
- 'type_error': HintSequence('name_error', 4),
- 'error': HintSequence('error', 2),
+ 'name_error': Hint('name_error'),
+ 'type_error': Hint('type_error'),
+ 'error': Hint('error'),
'time': Hint('time'),
'time_diff': Hint('time_diff'),
+ 'printing': Hint('printing'),
}
def test(python, code):
- passed = True
- hints = [{'id': 'test_results', 'args': {'passed': 0, 'total': 0}}]
+ # List of inputs: (expression to eval, stdin).
+ test_in = [
+ (None, '1\n'),
+ (None, '2\n'),
+ (None, '42\n'),
+ (None, '-42\n'),
+ (None, '0\n'),
+ ]
+ test_out = [
+ 1,
+ 2,
+ 42,
+ -42,
+ 0
+ ]
+
+ # List of outputs: (expression result, stdout, stderr, exception).
+ answers = python(code=code, inputs=test_in, timeout=1.0)
+ outputs = [ans[1] for ans in answers]
+
+ n_correct = 0
+ tin = None
+ for i, (output, correct) in enumerate(zip(outputs, test_out)):
+ if string_contains_number(output, correct):
+ n_correct += 1
+ else:
+ tin = test_in[i][1]
+ tout = correct
+
+ passed = n_correct == len(test_in)
+ hints = [{'id': 'test_results', 'args': {'passed': n_correct, 'total': len(test_in)}}]
+ if tin:
+ hints.append({'id': 'problematic_test_case', 'args': {'testin': str(tin), 'testout': str(tout)}})
return passed, hints
def hint(python, code):
+ tokens = get_tokens(code)
+
# run one test first to see if there are any exceptions
- test_in = [(None, '5\n')]
- answer = python(code=code, inputs=test_in, timeout=2.0)
+ test_in = [(None, '212\n')]
+ answer = python(code=code, inputs=test_in, timeout=1.0)
exc = answer[0][3]
+ exc_hint = get_exception_desc(answer[0][3])
# if have an exception!
if exc:
if 'NameError' in exc:
@@ -43,21 +78,18 @@ def hint(python, code):
elif 'TypeError' in exc:
return [{'id':'type_error', 'args': {'message': exc}}]
else:
- return [{'id':'error', 'args': {'message': exc}}]
+ return exc_hint
# First: if student does not import time, tell him about that module
- if not has_token_sequence(code, ['time']):
+ if not has_token_sequence(tokens, ['time']):
return [{'id': 'time'}]
- # show plan if student is lost
- # a) empty progam or
- # b) there is not input (we can do it here, since we have no input hint)
- if len(code.strip()) < 5 or (not has_token_sequence(code, ['input'])):
- return [{'id': 'plan'}]
-
# Student will have to compute time difference and they will need
# the substraction (-) operator to do this. Check for the minus operator.
- if not has_token_sequence(code, ['-']):
+ if not has_token_sequence(tokens, ['-']):
return [{'id' : 'time_diff'}]
+ if not string_contains_number(answer[0][1], 212):
+ return [{'id' : 'printing'}]
+
return None
diff --git a/python/problems/introduction/fast_fingers/sl.py b/python/problems/introduction/fast_fingers/sl.py
index f24718b..c4ae035 100644
--- a/python/problems/introduction/fast_fingers/sl.py
+++ b/python/problems/introduction/fast_fingers/sl.py
@@ -1,4 +1,6 @@
# coding=utf-8
+import server
+mod = server.problems.load_language('python', 'sl')
id = 190
name = 'Hitri prsti'
@@ -6,86 +8,69 @@ slug = 'Hitri prsti'
description = '''\
<p>Napiši program, ki uporabnika vpraša, koliko je 6 krat 7. Uporabnik bo premislil in vpisal odgovor.
-Program naj se ne ukvarja z odgovorom ter tem, ali je pravilen ali ne, temveč naj izpiše, koliko
+Program naj se ne ukvarja s tem, ali je odgovor pravilen ali ne, temveč naj ga le izpiše. Poleg tega naj izpiše, koliko
sekund je človek potreboval za razmišljanje.<p>
<pre>
Koliko je 6 krat 7? UPORABNIK VTIPKA 42
-Za razmišljanje ste porabili 2.503019332885742 s.
+Vpisal si 42. Za razmišljanje si porabil 2.503019332885742 s.
</pre>
-<p> Pri tej nalogi ni testnih primerov. </p>
'''
-general_exception = {
- 'error_head' : '''\
-<p>Napaka:</p>
-<pre>
-[%=message%]
-</pre>
-''',
-
- 'general': '''
-<p>Pri razumevanju napake sta pomembni dve vrstici. V predzadnji vrstici je napisana lokacija
-napake (line ...), v zadnji vrstici pa izvemo za kakšno napako gre.</p>
- ''',
-
- 'name_error' : '''
-<p>Napaka <code>NameError</code> pomeni, da uporabljate nedefinirano vrednost:
-ali vrednost spremenljivke ni določena ali uporabljate funkcijo, ki ni uvožena.</p>
- ''',
-
- 'type_error': '''
-<p>TypeError napaka pomeni, da želite izvesti operacijo na nedovoljenih tipih.
-Npr., če želite sešteti niz in število ali klicati funkcijo, čeprav tisto ni funkcija, itd. .</p>
- ''',
-}
-
-hint = {
- 'time': '''<p>V modulu <code>time</code> imate funkcijo <code>time</code>,
-ki vrača čas v sekundah od 1.januarja 1970 (ta datum označujemo tudi kot epoch oz. začete časa)
+time = ['''\
+<p>V modulu <code>time</code> imate funkcijo <code>time</code>''',
+ '''\
+<p>Funkcija <code>time</code> vrača čas v sekundah od 1.januarja 1970
+(ta datum označujemo tudi kot epoch oz. začete časa)
do trenutka, ko smo to funkcijo klicali. Poskusite:</p>
<pre>
from time import *
trenutno = time()
print("Od začetka časa je minilo že", trenutno, "sekund.")
-</pre>
- ''',
+</pre>''']
- 'plan': '''\
-<p>Če hočemo izračunati, koliko časa smo razmišljali, moramo poznati uro pred klicem funkcije input in
-po klicu funkcije input:</p>
-<ol>
-<li>Izmeri trenutni čas</li>
-<li>Vprašaj za rezultat</li>
-<li>Izmeri trenutni čas</li>
-<li>Izračunaj porabljen čas</li>
-<li>Izpiši</li>
-</ol>
-''',
-
- 'time_diff': '''
+time_diff = ['''\
<p>Porabljen čas lahko izračunamo tako, da od izmerjenega časa po vprašanju (konec) odštejemo
-izmerjen čas pred vprašanjem (zacetek):</p>
+izmerjen čas pred vprašanjem (zacetek):</p>''',
+ '''\
<pre>
zacetek = time()
...
konec = time()
cas = konec – zacetek
</pre>
+''']
+
+plan = ['''\
+<p>Če hočemo izračunati, koliko časa smo razmišljali, moramo poznati uro pred klicem funkcije input in
+po klicu funkcije input:</p>
+<ol>
+<li>Izmeri trenutni čas.</li>
+<li>Vprašaj za rezultat.</li>
+<li>Izmeri trenutni čas.</li>
+<li>Izračunaj porabljen čas.</li>
+<li>Izpiši rezultat in porabljen čas.</li>
+</ol>
''',
- 'name_error' : [general_exception['error_head'], general_exception['general'],
- general_exception['name_error'], '''
+ time,
+ time_diff]
+
+
+hint = {
+ 'time': time,
+ 'time_diff': time_diff,
+ 'printing:': '''<p>Izpiši rezultat!</p>''',
+ 'name_error' : [mod.general_msg['error_head'], mod.general_msg['general_exception'],
+ mod.general_msg['name_error'], '''
<p>Verjetno uporabljate spremenljivko, ki nima vrednosti. Ali v izrazu za izračun
uporabljate napačno spremenljivko? Ali pri izpisu morda poskušate
izpisati napačno spremenljivko?</p>'''],
- 'type_error' : [general_exception['error_head'], general_exception['general'],
- general_exception['type_error'], '''
+ 'type_error' : [mod.general_msg['error_head'], mod.general_msg['general_exception'],
+ mod.general_msg['type_error'], '''
<p>Verjetni razlog: funkcija <code>input</code> vrača vrednost tipa niz,
ki jo moramo najprej pretvoriti v tip <code>float</code>, če želimo z njo računati:</p>
<pre>
v = float(input(" ...
</pre>
'''],
-
- 'error' : [general_exception['error_head'], general_exception['general'],]
}