test_names.py 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. # -*- coding: utf-8 -*-
  2. import os
  3. import platform
  4. from grass.gunittest.case import TestCase
  5. from grass.gunittest.main import test
  6. import grass.script as gs
  7. from grass.script import legal_name
  8. from grass.script import utils
  9. class TestUnique(TestCase):
  10. """Tests functions generating unique names and suffixes"""
  11. def test_append_node_pid(self):
  12. base_name = "tmp_abc"
  13. full_name = utils.append_node_pid(base_name)
  14. self.assertIn(base_name, full_name)
  15. self.assertGreater(len(full_name), len(base_name))
  16. self.assertIn(str(os.getpid()), full_name)
  17. self.assertIn(utils.legalize_vector_name(platform.node()), full_name)
  18. self.assertTrue(legal_name(full_name))
  19. # TODO: It should be also a valid vector name
  20. # but we don't have a function for that (same for all)
  21. full_name2 = utils.append_node_pid(base_name)
  22. self.assertEqual(
  23. full_name, full_name2, msg="There should be no randomness or change."
  24. )
  25. def test_append_uuid(self):
  26. base_name = "tmp_abc"
  27. full_name = utils.append_uuid(base_name)
  28. self.assertIn(base_name, full_name)
  29. self.assertGreater(len(full_name), len(base_name))
  30. self.assertTrue(legal_name(full_name))
  31. full_name2 = utils.append_uuid(base_name)
  32. # There is a low chance of collision.
  33. self.assertNotEqual(full_name, full_name2)
  34. def test_append_random_suffix(self):
  35. base_name = "tmp_abc"
  36. size = 10
  37. full_name = utils.append_random(base_name, suffix_length=size)
  38. self.assertIn(base_name, full_name)
  39. self.assertGreater(len(full_name), len(base_name))
  40. self.assertGreaterEqual(len(full_name), len(base_name) + size)
  41. self.assertTrue(legal_name(full_name))
  42. full_name2 = utils.append_random(base_name, suffix_length=size)
  43. # There is a low chance of collision.
  44. self.assertNotEqual(full_name, full_name2)
  45. def test_append_random_total(self):
  46. base_name = "tmp_abc"
  47. size = 10
  48. full_name = utils.append_random(base_name, total_length=size)
  49. self.assertIn(base_name, full_name)
  50. self.assertGreater(len(full_name), len(base_name))
  51. self.assertEqual(len(full_name), size)
  52. self.assertTrue(legal_name(full_name))
  53. full_name2 = utils.append_random(base_name, total_length=size)
  54. self.assertNotEqual(full_name, full_name2)
  55. def test_append_random_one_arg(self):
  56. base_name = "tmp_abc"
  57. size = 10
  58. full_name = utils.append_random(base_name, size)
  59. self.assertIn(base_name, full_name)
  60. self.assertGreater(len(full_name), len(base_name))
  61. self.assertGreaterEqual(len(full_name), len(base_name) + size)
  62. self.assertTrue(legal_name(full_name))
  63. full_name2 = utils.append_random(base_name, size)
  64. self.assertNotEqual(full_name, full_name2)
  65. def test_append_random_two_args(self):
  66. base_name = "tmp_abc"
  67. size = 10
  68. self.assertRaises(ValueError, utils.append_random, base_name, size, size)
  69. def test_append_random_total_name_too_long(self):
  70. base_name = "tmp_abc"
  71. size = 4
  72. self.assertRaises(ValueError, utils.append_random, base_name, total_length=size)
  73. class TestLegalizeVectorName(TestCase):
  74. """Tests legalize_vector_name() function"""
  75. # Names for general tests (input, output)
  76. # Not ideal as the only tests don't show which one failed for errors which
  77. # are not assert failures.
  78. # Good for adding new combinations.
  79. names = [
  80. ("a", "a"),
  81. ("__abc__", "x__abc__"),
  82. ("125", "x125"),
  83. ("1a25g78g", "x1a25g78g"),
  84. ("_X1", "x_X1"),
  85. ("øaøbøcø", "x_a_b_c_"),
  86. ]
  87. def works_for_vector_table_column(self, name):
  88. """Try to create vector, with attribute table and a column with name
  89. Returns false when that fails. Does not report further errors.
  90. Use together with other tests.
  91. """
  92. try:
  93. gs.run_command("v.edit", map=name, tool="create")
  94. gs.run_command("v.db.addtable", map=name)
  95. gs.run_command("v.db.addcolumn", map=name, columns=name)
  96. works = True
  97. except gs.CalledModuleError:
  98. works = False
  99. finally:
  100. gs.run_command("g.remove", name=name, type="vector", flags="f")
  101. return works
  102. def test_is_legal_name(self):
  103. """Check that it is a G_legal_name()"""
  104. for name, reference in self.names:
  105. legalized = utils.legalize_vector_name(name)
  106. self.assertTrue(legal_name(legalized))
  107. self.assertEqual(legalized, reference)
  108. def test_is_working_in_vector_table_column(self):
  109. """Check that a vector and column can be created
  110. This indirectly tests that it is Vect_legal_name().
  111. """
  112. for name, reference in self.names:
  113. legalized = utils.legalize_vector_name(name)
  114. self.assertTrue(self.works_for_vector_table_column(legalized))
  115. self.assertEqual(legalized, reference)
  116. def test_no_change(self):
  117. """There should be no change if the name is valid already"""
  118. name = "perfectly_valid_name"
  119. legalized = utils.legalize_vector_name(name)
  120. self.assertEqual(legalized, name)
  121. self.assertTrue(legal_name(legalized))
  122. self.assertTrue(self.works_for_vector_table_column(legalized))
  123. def test_has_dashes(self):
  124. """Check behavior with dash (a typical and important case)"""
  125. name = "abc-def-1"
  126. legalized = utils.legalize_vector_name(name)
  127. self.assertEqual(legalized, "abc_def_1")
  128. self.assertTrue(legal_name(legalized))
  129. self.assertTrue(self.works_for_vector_table_column(legalized))
  130. def test_has_spaces(self):
  131. """Check behavior with a space"""
  132. name = "abc def 1"
  133. legalized = utils.legalize_vector_name(name)
  134. self.assertEqual(legalized, "abc_def_1")
  135. self.assertTrue(legal_name(legalized))
  136. self.assertTrue(self.works_for_vector_table_column(legalized))
  137. def test_has_at_sign(self):
  138. """Check behavior with @
  139. This can happen, e.g., when a full map name is used, so testing
  140. explicitly.
  141. """
  142. name = "abc@def"
  143. legalized = utils.legalize_vector_name(name)
  144. self.assertEqual(legalized, "abc_def")
  145. self.assertTrue(legal_name(legalized))
  146. self.assertTrue(self.works_for_vector_table_column(legalized))
  147. def test_has_dollar(self):
  148. """Check with one invalid character"""
  149. name = "abc_$def"
  150. legalized = utils.legalize_vector_name(name)
  151. self.assertEqual(legalized, "abc__def")
  152. self.assertTrue(legal_name(legalized))
  153. self.assertTrue(self.works_for_vector_table_column(legalized))
  154. def test_with_ascii_art(self):
  155. """Check with a lot of invalid characters"""
  156. name = "abc_>>>def<<<_!"
  157. legalized = utils.legalize_vector_name(name)
  158. self.assertEqual(legalized, "abc____def_____")
  159. self.assertTrue(legal_name(legalized))
  160. self.assertTrue(self.works_for_vector_table_column(legalized))
  161. def test_starts_with_digit(self):
  162. """Check string starting with digit"""
  163. name = "123456"
  164. legalized = utils.legalize_vector_name(name)
  165. self.assertEqual(legalized, "x123456")
  166. self.assertTrue(legal_name(legalized))
  167. self.assertTrue(self.works_for_vector_table_column(legalized))
  168. def test_starts_with_underscore(self):
  169. """Check string starting with underscore"""
  170. name = "_123456"
  171. legalized = utils.legalize_vector_name(name)
  172. self.assertEqual(legalized, "x_123456")
  173. self.assertTrue(legal_name(legalized))
  174. self.assertTrue(self.works_for_vector_table_column(legalized))
  175. def test_has_unicode(self):
  176. """Check string with unicode"""
  177. name = "abøc"
  178. legalized = utils.legalize_vector_name(name)
  179. self.assertEqual(legalized, "ab_c")
  180. self.assertTrue(legal_name(legalized))
  181. self.assertTrue(self.works_for_vector_table_column(legalized))
  182. def test_starts_with_unicode(self):
  183. """Check string starting with unicode"""
  184. name = "øabc"
  185. legalized = utils.legalize_vector_name(name)
  186. self.assertEqual(legalized, "x_abc")
  187. self.assertTrue(legal_name(legalized))
  188. self.assertTrue(self.works_for_vector_table_column(legalized))
  189. def test_diff_only_first_character(self):
  190. """Check two string with only the first character being different"""
  191. name1 = "1800"
  192. name2 = "2800"
  193. legalized1 = utils.legalize_vector_name(name1)
  194. legalized2 = utils.legalize_vector_name(name2)
  195. self.assertNotEqual(legalized1, legalized2)
  196. def test_custom_prefix(self):
  197. """Check providing custom prefix"""
  198. name = "1800"
  199. prefix = "prefix_a1_"
  200. legalized = utils.legalize_vector_name(name, fallback_prefix=prefix)
  201. self.assertEqual(len(prefix) + len(name), len(legalized))
  202. self.assertIn(prefix, legalized)
  203. def test_no_prefix(self):
  204. """Check providing custom prefix"""
  205. name = "1800"
  206. legalized = utils.legalize_vector_name(name, fallback_prefix="")
  207. self.assertEqual(len(name), len(legalized))
  208. if __name__ == "__main__":
  209. test()