summaryrefslogtreecommitdiffstats
path: root/day9/test_init.py
blob: eb889c7d8cc2a3a1f2579eca93c679074a7d5a3d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
# -*- coding: utf-8 -*-
import os.path

import day9


class TestAssignment:
    def test_right(self):
        expected = "\n".join(
            [
                "s###..",
            ]
        )

        input = ["R 4"]

        assignment = day9.AssignmentOne(path=os.path.dirname(day9.__file__))
        unique_positions = assignment.unique_tail_positions(input=input, length=2)

        assert assignment.visualize(range(6), range(1), unique_positions) == expected

    def test_left(self):
        expected = "\n".join(
            [
                "..###s",
            ]
        )

        input = ["L 4"]

        assignment = day9.AssignmentOne(path=os.path.dirname(day9.__file__))
        unique_positions = assignment.unique_tail_positions(input=input, length=2)

        assert (
            assignment.visualize(range(-5, 1), range(1), unique_positions) == expected
        )

    def test_up(self):
        expected = "\n".join(
            [
                ".",
                ".",
                "#",
                "#",
                "#",
                "s",
            ]
        )

        input = ["U 4"]

        assignment = day9.AssignmentOne(path=os.path.dirname(day9.__file__))
        unique_positions = assignment.unique_tail_positions(input=input, length=2)

        assert assignment.visualize(range(1), range(6), unique_positions) == expected

    def test_down(self):
        expected = "\n".join(
            [
                "s",
                "#",
                "#",
                "#",
                ".",
                ".",
            ]
        )

        input = ["D 4"]

        assignment = day9.AssignmentOne(path=os.path.dirname(day9.__file__))
        unique_positions = assignment.unique_tail_positions(input=input, length=2)

        assert (
            assignment.visualize(range(1), range(-5, 1), unique_positions) == expected
        )


class TestAssignmentOne:
    def test_output_visualization(self):
        expected = "\n".join(["..##..", "...##.", ".####.", "....#.", "s###.."])

        assignment = day9.AssignmentOne(path=os.path.dirname(day9.__file__))
        unique_positions = assignment.unique_tail_positions(
            input=assignment.read_input(True), length=2
        )
        assert assignment.visualize(range(6), range(5), unique_positions) == expected


class TestAssignmentTwo:
    def test_output_visualization(self):
        expected = "\n".join(
            [
                "..........................",
                "..........................",
                "..........................",
                "..........................",
                "..........................",
                "..........................",
                "..........................",
                "..........................",
                "..........................",
                "#.........................",
                "#.............###.........",
                "#............#...#........",
                ".#..........#.....#.......",
                "..#..........#.....#......",
                "...#........#.......#.....",
                "....#......s.........#....",
                ".....#..............#.....",
                "......#............#......",
                ".......#..........#.......",
                "........#........#........",
                ".........########.........",
            ]
        )

        assignment = day9.AssignmentTwo(path=os.path.dirname(day9.__file__))
        unique_positions = assignment.unique_tail_positions(
            input=assignment.read_input(True),
            length=10,
        )
        assert (
            assignment.visualize(range(-11, 15), range(-5, 16), unique_positions)
            == expected
        )