2
# -*- coding: utf-8 -*-
10
ROOT = os.path.abspath(os.path.join(os.path.dirname(__file__), '..'))
11
sys.path.insert(0, ROOT)
13
import pygooglechart as gc
14
from pygooglechart import NoDataGivenException
17
class TestBase(unittest.TestCase):
21
# All tests require warnings to be raised
22
self.raise_warnings(True)
24
def raise_warnings(self, rw):
28
warnings.simplefilter('error')
30
# Don't print out warnings if we're expecting them--so we can have
31
# nicer looking tests! :)
32
warnings.simplefilter('ignore')
34
def assertChartURL(self, url, query):
35
self.assertTrue(url.endswith(query))
38
class TestDataTypes(TestBase):
40
def test_simple_data(self):
41
s = gc.SimpleData([range(0, 62), [0, 1, 60, 61]])
42
self.assertEquals(repr(s),
43
'chd=s:ABCDEFGHIJKLMNOPQRSTUVWXYZ'
44
'abcdefghijklmnopqrstuvwxyz0123456789,AB89')
46
def test_text_data(self):
47
s = gc.TextData([[0, 1, 99.9]])
48
self.assertEquals(repr(s), 'chd=t:0.0,1.0,99.9')
50
def test_ext_data(self):
51
s = gc.ExtendedData([[0, 1, 4095]])
52
self.assertEquals(repr(s), 'chd=e:AAAB..')
55
class TestScaling(TestBase):
57
def test_simple_scale(self):
58
sv = gc.SimpleData.scale_value
60
self.raise_warnings(False) # We know some of these give warnings
61
self.assertEquals(sv(-10, [0, 1]), 0)
62
self.assertEquals(sv(0, [0, 1]), 0)
63
self.assertEquals(sv(.5, [0, 1]), 31)
64
self.assertEquals(sv(30, [0, 1]), 61)
65
self.assertEquals(sv(2222, [0, 10000]), 14)
68
self.raise_warnings(True)
69
self.assertRaises(UserWarning, sv, -10, [0, 1])
70
self.assertRaises(UserWarning, sv, 30, [0, 1])
72
def test_text_scale(self):
73
sv = gc.TextData.scale_value
75
self.raise_warnings(False)
76
self.assertEquals(sv(-10, [0, 1]), 0)
77
self.assertEquals(sv(0, [0, 1]), 0)
78
self.assertEquals(sv(.5, [0, 1]), 50)
79
self.assertEquals(sv(30, [0, 1]), 100)
80
self.assertEquals(sv(2222, [0, 10000]), 22.22)
82
self.raise_warnings(True)
83
self.assertRaises(UserWarning, sv, -10, [0, 1])
84
self.assertRaises(UserWarning, sv, 30, [0, 1])
86
def test_ext_scale(self):
87
sv = gc.ExtendedData.scale_value
89
self.raise_warnings(False)
90
self.assertEquals(sv(-10, [0, 1]), 0)
91
self.assertEquals(sv(0, [0, 1]), 0)
92
self.assertEquals(sv(.5, [0, 1]), 2048)
93
self.assertEquals(sv(30, [0, 1]), 4095)
94
self.assertEquals(sv(2222, [0, 10000]), 910)
96
self.raise_warnings(True)
97
self.assertRaises(UserWarning, sv, -10, [0, 1])
98
self.assertRaises(UserWarning, sv, 30, [0, 1])
101
class TestLineChart(TestBase):
103
def test_none_data(self):
104
chart = gc.SimpleLineChart(300, 100)
105
chart.add_data([1, 2, 3, None, 5])
106
self.assertChartURL(chart.get_url(), \
107
'?cht=lc&chs=300x100&chd=e:KrVVgA__1V')
109
class TestQRChart(TestBase):
111
def assertQRImage(self, chart, text):
115
print 'PyQrCodec not installed. Can not test QR code image'
120
status, string = PyQrcodec.decode(fn)
121
self.assertTrue(status)
122
self.assertEquals(text, string)
124
def test_simple(self):
126
chart = gc.QRChart(100, 150)
128
self.assertChartURL(chart.get_url(), \
129
'?cht=qr&chs=100x150&chl=Hello%20World')
131
def test_encoding(self):
132
chart = gc.QRChart(100, 100)
133
chart.add_data('Hello World')
134
self.assertChartURL(chart.get_url(), \
135
'?cht=qr&chs=100x100&chl=Hello%20World')
137
def test_no_data(self):
138
chart = gc.QRChart(100, 100)
139
self.assertRaises(NoDataGivenException, chart.get_url)
141
def test_validate_image(self):
143
chart = gc.QRChart(100, 100)
145
chart.set_ec('H', 0) # PyQrcodec seems to only work on higher EC
146
self.assertQRImage(chart, text)
148
def test_validate_utf8(self):
149
text = 'こんにちは世界' # Hello world in Japanese UTF8
150
chart = gc.QRChart(100, 100)
153
self.assertQRImage(chart, text)
155
def test_validate_shift_jis(self):
156
# XXX: It looks like PyQrcodec doesn't do shift_jis?
157
text = unicode('こんにちは世界', 'utf-8').encode('shift_jis')
158
chart = gc.QRChart(100, 100)
161
chart.set_encoding('Shift_JIS')
162
self.assertChartURL(chart.get_url(), \
163
'?cht=qr&chs=100x100&chl=%82%B1%82%F1%82%C9' \
164
'%82%BF%82%CD%90%A2%8AE&choe=Shift_JIS&chld=H|0')
165
chart.download('temp.png')
168
class TestGrammar(TestBase):
170
types = ('Venn', 'GroupedHorizontalBar', 'GoogleOMeter', 'Scatter',
171
'StackedVerticalBar', 'Map', 'StackedHorizontalBar', 'SimpleLine',
172
'SparkLine', 'GroupedVerticalBar', 'SplineRadar', 'XYLine', 'Radar',
175
def test_chart_types(self):
176
ret = gc.ChartGrammar.get_possible_chart_types()
177
diff = set(ret).symmetric_difference(set(TestGrammar.types))
178
self.assert_(not diff)
180
def test_google_chart(self):
182
'type': 'GoogleOMeter',
186
'x_range': [ 0, 10 ],
191
grammar = gc.ChartGrammar()
192
chart = grammar.parse(g)
193
# print chart.get_url()
194
# chart.download('meh.png')
197
if __name__ == "__main__":