/django/contrib/gis/tests/test_measure.py

https://code.google.com/p/mango-py/ · Python · 337 lines · 270 code · 63 blank · 4 comment · 50 complexity · 497f6cf85029898ac59f61eed39ebac8 MD5 · raw file

  1. """
  2. Distance and Area objects to allow for sensible and convienient calculation
  3. and conversions. Here are some tests.
  4. """
  5. from django.contrib.gis.measure import Distance, Area, D, A
  6. from django.utils import unittest
  7. class DistanceTest(unittest.TestCase):
  8. "Testing the Distance object"
  9. def testInit(self):
  10. "Testing initialisation from valid units"
  11. d = Distance(m=100)
  12. self.assertEqual(d.m, 100)
  13. d1, d2, d3 = D(m=100), D(meter=100), D(metre=100)
  14. for d in (d1, d2, d3):
  15. self.assertEqual(d.m, 100)
  16. d = D(nm=100)
  17. self.assertEqual(d.m, 185200)
  18. y1, y2, y3 = D(yd=100), D(yard=100), D(Yard=100)
  19. for d in (y1, y2, y3):
  20. self.assertEqual(d.yd, 100)
  21. mm1, mm2 = D(millimeter=1000), D(MiLLiMeTeR=1000)
  22. for d in (mm1, mm2):
  23. self.assertEqual(d.m, 1.0)
  24. self.assertEqual(d.mm, 1000.0)
  25. def testInitInvalid(self):
  26. "Testing initialisation from invalid units"
  27. self.assertRaises(AttributeError, D, banana=100)
  28. def testAccess(self):
  29. "Testing access in different units"
  30. d = D(m=100)
  31. self.assertEqual(d.km, 0.1)
  32. self.assertAlmostEqual(d.ft, 328.084, 3)
  33. def testAccessInvalid(self):
  34. "Testing access in invalid units"
  35. d = D(m=100)
  36. self.failIf(hasattr(d, 'banana'))
  37. def testAddition(self):
  38. "Test addition & subtraction"
  39. d1 = D(m=100)
  40. d2 = D(m=200)
  41. d3 = d1 + d2
  42. self.assertEqual(d3.m, 300)
  43. d3 += d1
  44. self.assertEqual(d3.m, 400)
  45. d4 = d1 - d2
  46. self.assertEqual(d4.m, -100)
  47. d4 -= d1
  48. self.assertEqual(d4.m, -200)
  49. try:
  50. d5 = d1 + 1
  51. except TypeError, e:
  52. pass
  53. else:
  54. self.fail('Distance + number should raise TypeError')
  55. try:
  56. d5 = d1 - 1
  57. except TypeError, e:
  58. pass
  59. else:
  60. self.fail('Distance - number should raise TypeError')
  61. try:
  62. d1 += 1
  63. except TypeError, e:
  64. pass
  65. else:
  66. self.fail('Distance += number should raise TypeError')
  67. try:
  68. d1 -= 1
  69. except TypeError, e:
  70. pass
  71. else:
  72. self.fail('Distance -= number should raise TypeError')
  73. def testMultiplication(self):
  74. "Test multiplication & division"
  75. d1 = D(m=100)
  76. d3 = d1 * 2
  77. self.assertEqual(d3.m, 200)
  78. d3 = 2 * d1
  79. self.assertEqual(d3.m, 200)
  80. d3 *= 5
  81. self.assertEqual(d3.m, 1000)
  82. d4 = d1 / 2
  83. self.assertEqual(d4.m, 50)
  84. d4 /= 5
  85. self.assertEqual(d4.m, 10)
  86. a5 = d1 * D(m=10)
  87. self.assertTrue(isinstance(a5, Area))
  88. self.assertEqual(a5.sq_m, 100*10)
  89. try:
  90. d1 *= D(m=1)
  91. except TypeError, e:
  92. pass
  93. else:
  94. self.fail('Distance *= Distance should raise TypeError')
  95. try:
  96. d5 = d1 / D(m=1)
  97. except TypeError, e:
  98. pass
  99. else:
  100. self.fail('Distance / Distance should raise TypeError')
  101. try:
  102. d1 /= D(m=1)
  103. except TypeError, e:
  104. pass
  105. else:
  106. self.fail('Distance /= Distance should raise TypeError')
  107. def testUnitConversions(self):
  108. "Testing default units during maths"
  109. d1 = D(m=100)
  110. d2 = D(km=1)
  111. d3 = d1 + d2
  112. self.assertEqual(d3._default_unit, 'm')
  113. d4 = d2 + d1
  114. self.assertEqual(d4._default_unit, 'km')
  115. d5 = d1 * 2
  116. self.assertEqual(d5._default_unit, 'm')
  117. d6 = d1 / 2
  118. self.assertEqual(d6._default_unit, 'm')
  119. def testComparisons(self):
  120. "Testing comparisons"
  121. d1 = D(m=100)
  122. d2 = D(km=1)
  123. d3 = D(km=0)
  124. self.assertTrue(d2 > d1)
  125. self.assertTrue(d1 == d1)
  126. self.assertTrue(d1 < d2)
  127. self.failIf(d3)
  128. def testUnitsStr(self):
  129. "Testing conversion to strings"
  130. d1 = D(m=100)
  131. d2 = D(km=3.5)
  132. self.assertEqual(str(d1), '100.0 m')
  133. self.assertEqual(str(d2), '3.5 km')
  134. self.assertEqual(repr(d1), 'Distance(m=100.0)')
  135. self.assertEqual(repr(d2), 'Distance(km=3.5)')
  136. def testUnitAttName(self):
  137. "Testing the `unit_attname` class method"
  138. unit_tuple = [('Yard', 'yd'), ('Nautical Mile', 'nm'), ('German legal metre', 'german_m'),
  139. ('Indian yard', 'indian_yd'), ('Chain (Sears)', 'chain_sears'), ('Chain', 'chain')]
  140. for nm, att in unit_tuple:
  141. self.assertEqual(att, D.unit_attname(nm))
  142. class AreaTest(unittest.TestCase):
  143. "Testing the Area object"
  144. def testInit(self):
  145. "Testing initialisation from valid units"
  146. a = Area(sq_m=100)
  147. self.assertEqual(a.sq_m, 100)
  148. a = A(sq_m=100)
  149. self.assertEqual(a.sq_m, 100)
  150. a = A(sq_mi=100)
  151. self.assertEqual(a.sq_m, 258998811.0336)
  152. def testInitInvaliA(self):
  153. "Testing initialisation from invalid units"
  154. self.assertRaises(AttributeError, A, banana=100)
  155. def testAccess(self):
  156. "Testing access in different units"
  157. a = A(sq_m=100)
  158. self.assertEqual(a.sq_km, 0.0001)
  159. self.assertAlmostEqual(a.sq_ft, 1076.391, 3)
  160. def testAccessInvaliA(self):
  161. "Testing access in invalid units"
  162. a = A(sq_m=100)
  163. self.failIf(hasattr(a, 'banana'))
  164. def testAddition(self):
  165. "Test addition & subtraction"
  166. a1 = A(sq_m=100)
  167. a2 = A(sq_m=200)
  168. a3 = a1 + a2
  169. self.assertEqual(a3.sq_m, 300)
  170. a3 += a1
  171. self.assertEqual(a3.sq_m, 400)
  172. a4 = a1 - a2
  173. self.assertEqual(a4.sq_m, -100)
  174. a4 -= a1
  175. self.assertEqual(a4.sq_m, -200)
  176. try:
  177. a5 = a1 + 1
  178. except TypeError, e:
  179. pass
  180. else:
  181. self.fail('Area + number should raise TypeError')
  182. try:
  183. a5 = a1 - 1
  184. except TypeError, e:
  185. pass
  186. else:
  187. self.fail('Area - number should raise TypeError')
  188. try:
  189. a1 += 1
  190. except TypeError, e:
  191. pass
  192. else:
  193. self.fail('Area += number should raise TypeError')
  194. try:
  195. a1 -= 1
  196. except TypeError, e:
  197. pass
  198. else:
  199. self.fail('Area -= number should raise TypeError')
  200. def testMultiplication(self):
  201. "Test multiplication & division"
  202. a1 = A(sq_m=100)
  203. a3 = a1 * 2
  204. self.assertEqual(a3.sq_m, 200)
  205. a3 = 2 * a1
  206. self.assertEqual(a3.sq_m, 200)
  207. a3 *= 5
  208. self.assertEqual(a3.sq_m, 1000)
  209. a4 = a1 / 2
  210. self.assertEqual(a4.sq_m, 50)
  211. a4 /= 5
  212. self.assertEqual(a4.sq_m, 10)
  213. try:
  214. a5 = a1 * A(sq_m=1)
  215. except TypeError, e:
  216. pass
  217. else:
  218. self.fail('Area * Area should raise TypeError')
  219. try:
  220. a1 *= A(sq_m=1)
  221. except TypeError, e:
  222. pass
  223. else:
  224. self.fail('Area *= Area should raise TypeError')
  225. try:
  226. a5 = a1 / A(sq_m=1)
  227. except TypeError, e:
  228. pass
  229. else:
  230. self.fail('Area / Area should raise TypeError')
  231. try:
  232. a1 /= A(sq_m=1)
  233. except TypeError, e:
  234. pass
  235. else:
  236. self.fail('Area /= Area should raise TypeError')
  237. def testUnitConversions(self):
  238. "Testing default units during maths"
  239. a1 = A(sq_m=100)
  240. a2 = A(sq_km=1)
  241. a3 = a1 + a2
  242. self.assertEqual(a3._default_unit, 'sq_m')
  243. a4 = a2 + a1
  244. self.assertEqual(a4._default_unit, 'sq_km')
  245. a5 = a1 * 2
  246. self.assertEqual(a5._default_unit, 'sq_m')
  247. a6 = a1 / 2
  248. self.assertEqual(a6._default_unit, 'sq_m')
  249. def testComparisons(self):
  250. "Testing comparisons"
  251. a1 = A(sq_m=100)
  252. a2 = A(sq_km=1)
  253. a3 = A(sq_km=0)
  254. self.assertTrue(a2 > a1)
  255. self.assertTrue(a1 == a1)
  256. self.assertTrue(a1 < a2)
  257. self.failIf(a3)
  258. def testUnitsStr(self):
  259. "Testing conversion to strings"
  260. a1 = A(sq_m=100)
  261. a2 = A(sq_km=3.5)
  262. self.assertEqual(str(a1), '100.0 sq_m')
  263. self.assertEqual(str(a2), '3.5 sq_km')
  264. self.assertEqual(repr(a1), 'Area(sq_m=100.0)')
  265. self.assertEqual(repr(a2), 'Area(sq_km=3.5)')
  266. def suite():
  267. s = unittest.TestSuite()
  268. s.addTest(unittest.makeSuite(DistanceTest))
  269. s.addTest(unittest.makeSuite(AreaTest))
  270. return s
  271. def run(verbosity=2):
  272. unittest.TextTestRunner(verbosity=verbosity).run(suite())
  273. if __name__=="__main__":
  274. run()