-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathexercise (5).py
76 lines (59 loc) · 1.68 KB
/
exercise (5).py
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
# class Shape:
# def __init__(self):
# self.name = None
#
#
# class Triangle(Shape):
# def __init__(self):
# super().__init__()
# self.name = 'Triangle'
#
#
# class Square(Shape):
# def __init__(self):
# super().__init__()
# self.name = 'Square'
#
#
# class VectorSquare(Square):
# def __str__(self):
# return f'Drawing {self.name} as lines'
#
#
# class RasterSquare(Square):
# def __str__(self):
# return f'Drawing {self.name} as pixels'
# imagine VectorTriangle and RasterTriangle are here too
import unittest
from abc import ABC
class Renderer(ABC):
@property
def what_to_render_as(self):
return None
class Shape(ABC):
def __init__(self, renderer, name):
self.renderer = renderer
self.name = name
def __str__(self):
return "Drawing %s as %s" % (self.name, self.renderer.what_to_render_as)
class Triangle(Shape):
def __init__(self, renderer):
super().__init__(renderer, "Triangle")
class Square(Shape):
def __init__(self, renderer):
super().__init__(renderer, "Square")
class RasterRenderer(Renderer):
@property
def what_to_render_as(self):
return "pixels"
class VectorRenderer(Renderer):
@property
def what_to_render_as(self):
return "lines"
class Evaluate(unittest.TestCase):
def test_square_vector(self):
sq = Square(VectorRenderer())
self.assertEqual(str(sq), "Drawing Square as lines")
def test_pixel_triangle(self):
tr = Triangle(RasterRenderer())
self.assertEqual(str(tr), "Drawing Triangle as pixels")