[daa2276] | 1 | import pytest
|
---|
| 2 | import json
|
---|
| 3 |
|
---|
| 4 | from flowtimer.Phase import Phase
|
---|
| 5 | from flowtimer.RecurringPhaseSequence import RecurringPhaseSequence
|
---|
| 6 |
|
---|
| 7 |
|
---|
| 8 | class TestRecurringPhaseSequence():
|
---|
| 9 |
|
---|
| 10 | @pytest.fixture
|
---|
| 11 | def recurring_phase_sequence(self):
|
---|
| 12 | phase_list = [Phase("Huddle", 10), Phase("Tasking", 5),
|
---|
| 13 | Phase("Work", 45), Phase("Break", 15)]
|
---|
| 14 | return RecurringPhaseSequence(phase_list, 3)
|
---|
| 15 |
|
---|
| 16 | def test_from_json(self):
|
---|
| 17 | json_string = RecurringPhaseSequence.default_json_string()
|
---|
| 18 | sequence = RecurringPhaseSequence.from_json(json_string)
|
---|
| 19 | assert isinstance(sequence, RecurringPhaseSequence)
|
---|
| 20 | assert sequence.initial_repetitions == 3
|
---|
| 21 | assert len(sequence.phase_list) == 4
|
---|
| 22 | assert sequence.phase_list[0].title == "Huddle"
|
---|
| 23 |
|
---|
| 24 | def test_to_json(self, recurring_phase_sequence):
|
---|
| 25 | json_string = recurring_phase_sequence.to_json()
|
---|
| 26 | data = json.loads(json_string)
|
---|
| 27 | assert data['state'] == "initial"
|
---|
| 28 | assert data['initial_repetitions'] == 3
|
---|
| 29 | assert data['passes_left'] == 3
|
---|
| 30 | assert len(data['phase_list']) == 4
|
---|
| 31 |
|
---|
| 32 | def test_initial_state(self, recurring_phase_sequence):
|
---|
| 33 | assert recurring_phase_sequence.state == "initial"
|
---|
| 34 | assert recurring_phase_sequence.current_phase.title == "Huddle"
|
---|
| 35 | assert recurring_phase_sequence.passes_left == 3
|
---|
| 36 |
|
---|
| 37 | def test_current_phase_number(self, recurring_phase_sequence):
|
---|
| 38 | assert recurring_phase_sequence.current_phase_number() == 0
|
---|
| 39 | recurring_phase_sequence.tick(10)
|
---|
| 40 | assert recurring_phase_sequence.current_phase_number() == 1
|
---|
| 41 |
|
---|
| 42 | def test_phases_left_in_pass(self, recurring_phase_sequence):
|
---|
| 43 | assert recurring_phase_sequence.phases_left_in_pass() == 3
|
---|
| 44 | recurring_phase_sequence.tick(10)
|
---|
| 45 | assert recurring_phase_sequence.phases_left_in_pass() == 2
|
---|
| 46 |
|
---|
| 47 | def test_upcoming_phases_in_pass(self, recurring_phase_sequence):
|
---|
| 48 | upcoming = recurring_phase_sequence.upcoming_phases_in_pass()
|
---|
| 49 | assert len(upcoming) == 3
|
---|
| 50 | assert upcoming[0].title == "Tasking"
|
---|
| 51 |
|
---|
| 52 | def test_ticks_left(self, recurring_phase_sequence):
|
---|
| 53 | total_ticks = (sum([phase.initial_ticks for phase in recurring_phase_sequence.phase_list]) *
|
---|
| 54 | recurring_phase_sequence.initial_repetitions)
|
---|
| 55 |
|
---|
| 56 | assert recurring_phase_sequence.ticks_left == total_ticks
|
---|
| 57 | recurring_phase_sequence.tick(10)
|
---|
| 58 | assert recurring_phase_sequence.ticks_left == (total_ticks - 10)
|
---|
| 59 |
|
---|
| 60 | def test_finished(self, recurring_phase_sequence):
|
---|
| 61 | assert not recurring_phase_sequence.finished()
|
---|
| 62 | for _ in range(3):
|
---|
| 63 | for phase in recurring_phase_sequence.phase_list:
|
---|
| 64 | recurring_phase_sequence.tick(phase.initial_ticks)
|
---|
| 65 | assert recurring_phase_sequence.finished()
|
---|
| 66 |
|
---|
| 67 | def test_abort(self, recurring_phase_sequence):
|
---|
| 68 | recurring_phase_sequence.abort()
|
---|
| 69 | assert recurring_phase_sequence.state == "finished"
|
---|
| 70 | assert recurring_phase_sequence.current_phase.finished()
|
---|
| 71 |
|
---|
| 72 | def test_tick_progression(self, recurring_phase_sequence):
|
---|
| 73 | recurring_phase_sequence.tick(10)
|
---|
| 74 | assert recurring_phase_sequence.current_phase.title == "Tasking"
|
---|
| 75 | assert recurring_phase_sequence.passes_left == 3
|
---|
| 76 |
|
---|
| 77 | recurring_phase_sequence.tick(5)
|
---|
| 78 | assert recurring_phase_sequence.current_phase.title == "Work"
|
---|
| 79 | assert recurring_phase_sequence.passes_left == 3
|
---|
| 80 |
|
---|
| 81 | recurring_phase_sequence.tick(45)
|
---|
| 82 | assert recurring_phase_sequence.current_phase.title == "Break"
|
---|
| 83 | assert recurring_phase_sequence.passes_left == 3
|
---|
| 84 |
|
---|
| 85 | recurring_phase_sequence.tick(15)
|
---|
| 86 | assert recurring_phase_sequence.current_phase.title == "Huddle"
|
---|
| 87 | assert recurring_phase_sequence.passes_left == 2
|
---|
| 88 |
|
---|
| 89 | def test_unrolled(self, recurring_phase_sequence):
|
---|
| 90 | unrolled_phases = recurring_phase_sequence.unrolled()
|
---|
| 91 | assert len(unrolled_phases) == 12
|
---|
| 92 | assert unrolled_phases[0].title == "Huddle"
|
---|
| 93 | assert unrolled_phases[-1].title == "Break"
|
---|