You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
73 lines
3.4 KiB
73 lines
3.4 KiB
3 years ago
|
import unittest
|
||
|
import pytest
|
||
|
|
||
|
|
||
|
try:
|
||
|
from lasagna import (EXPECTED_BAKE_TIME,
|
||
|
bake_time_remaining,
|
||
|
preparation_time_in_minutes,
|
||
|
elapsed_time_in_minutes)
|
||
|
|
||
|
|
||
|
except ImportError as import_fail:
|
||
|
message = import_fail.args[0].split('(', maxsplit=1)
|
||
|
item_name = import_fail.args[0].split()[3]
|
||
|
|
||
|
if 'EXPECTED_BAKE_TIME' in message:
|
||
|
# pylint: disable=raise-missing-from
|
||
|
raise ImportError(f'We can not find or import the constant {item_name} in your'
|
||
|
" 'lasagna.py' file. Did you mis-name or forget to define it?")
|
||
|
else:
|
||
|
item_name = item_name[:-1] + "()'"
|
||
|
# pylint: disable=raise-missing-from
|
||
|
raise ImportError("In your 'lasagna.py' file, we can not find or import the"
|
||
|
f' function named {item_name}. Did you mis-name or forget to define it?')
|
||
|
|
||
|
|
||
|
class LasagnaTest(unittest.TestCase):
|
||
|
|
||
|
@pytest.mark.task(taskno=1)
|
||
|
def test_EXPECTED_BAKE_TIME(self):
|
||
|
failure_msg = 'Expected a constant of EXPECTED_BAKE_TIME with a value of 40.'
|
||
|
self.assertEqual(EXPECTED_BAKE_TIME, 40, msg=failure_msg)
|
||
|
|
||
|
@pytest.mark.task(taskno=2)
|
||
|
def test_bake_time_remaining(self):
|
||
|
input_data = [1, 2, 5, 10, 15, 23, 33, 39]
|
||
|
result_data = [40 - item for item in input_data]
|
||
|
|
||
|
for variant, (time, result) in enumerate(zip(input_data, result_data), start=1):
|
||
|
with self.subTest(f'variation #{variant}', time=time, result=result):
|
||
|
failure_msg = f'Expected: {result} but the bake time remaining was calculated incorrectly.'
|
||
|
self.assertEqual(bake_time_remaining(time), result, msg=failure_msg)
|
||
|
|
||
|
@pytest.mark.task(taskno=3)
|
||
|
def test_preparation_time_in_minutes(self):
|
||
|
input_data = [1, 2, 5, 8, 11, 15]
|
||
|
result_data = [item * 2 for item in input_data]
|
||
|
|
||
|
for variant, (layers, time) in enumerate(zip(input_data, result_data), start=1):
|
||
|
with self.subTest(f'variation #{variant}', layers=layers, time=time):
|
||
|
failure_msg = f'Expected: {time} minutes, but preparation time was calculated incorrectly.'
|
||
|
self.assertEqual(preparation_time_in_minutes(layers), time, msg=failure_msg)
|
||
|
|
||
|
@pytest.mark.task(taskno=4)
|
||
|
def test_elapsed_time_in_minutes(self):
|
||
|
layer_data = (1, 2, 5, 8, 11, 15)
|
||
|
time_data = (3, 7, 8, 4, 15, 20)
|
||
|
result_data = [prep * 2 + elapsed for prep, elapsed in zip(layer_data, time_data)]
|
||
|
|
||
|
for variant, (layers, time, total_time) in enumerate(zip(layer_data, time_data, result_data), start=1):
|
||
|
with self.subTest(f'variation #{variant}', layers=layers, time=time, total_time=total_time):
|
||
|
failure_msg = f'Expected {time} minutes elapsed, but the timing was calculated incorrectly.'
|
||
|
self.assertEqual(elapsed_time_in_minutes(layers, time), total_time, msg=failure_msg)
|
||
|
|
||
|
@pytest.mark.task(taskno=5)
|
||
|
def test_docstrings_were_written(self):
|
||
|
functions = [bake_time_remaining, preparation_time_in_minutes, elapsed_time_in_minutes]
|
||
|
|
||
|
for variant, function in enumerate(functions, start=1):
|
||
|
with self.subTest(f'variation #{variant}', function=function):
|
||
|
failure_msg = f'Expected a docstring for `{function.__name__}`, but received `None` instead.'
|
||
|
self.assertIsNotNone(function.__doc__, msg=failure_msg)
|