test_raster_metadata.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. """Test of raster library metadata handling
  2. @author Maris Nartiss
  3. @copyright 2021 by Maris Nartiss and the GRASS Development Team
  4. @license This program is free software under the GNU General Public License (>=v2).
  5. Read the file COPYING that comes with GRASS
  6. for details
  7. """
  8. import random
  9. import string
  10. from grass.gunittest.case import TestCase
  11. from grass.gunittest.main import test
  12. from grass.script.core import tempname
  13. from grass.pygrass.gis import Mapset
  14. from grass.pygrass import utils
  15. from grass.lib.gis import G_remove_misc
  16. from grass.lib.raster import (
  17. Rast_legal_semantic_label,
  18. Rast_read_semantic_label,
  19. Rast_get_semantic_label_or_name,
  20. Rast_write_semantic_label,
  21. )
  22. class RastLegalBandIdTestCase(TestCase):
  23. def test_empty_name(self):
  24. ret = Rast_legal_semantic_label("")
  25. self.assertEqual(ret, False)
  26. ret = Rast_legal_semantic_label(" ")
  27. self.assertEqual(ret, False)
  28. def test_illegal_name(self):
  29. ret = Rast_legal_semantic_label(".a")
  30. self.assertEqual(ret, False)
  31. ret = Rast_legal_semantic_label("a/b")
  32. self.assertEqual(ret, False)
  33. ret = Rast_legal_semantic_label("a@b")
  34. self.assertEqual(ret, False)
  35. ret = Rast_legal_semantic_label("a#b")
  36. self.assertEqual(ret, False)
  37. def test_too_long(self):
  38. ret = Rast_legal_semantic_label(
  39. "a_" + "".join(random.choices(string.ascii_letters, k=253))
  40. )
  41. self.assertEqual(ret, True)
  42. ret = Rast_legal_semantic_label(
  43. "a_" + "".join(random.choices(string.ascii_letters, k=254))
  44. )
  45. self.assertEqual(ret, False)
  46. def test_good_name(self):
  47. ret = Rast_legal_semantic_label("1")
  48. self.assertEqual(ret, True)
  49. ret = Rast_legal_semantic_label("1a")
  50. self.assertEqual(ret, True)
  51. ret = Rast_legal_semantic_label("clouds")
  52. self.assertEqual(ret, True)
  53. ret = Rast_legal_semantic_label("rededge1")
  54. self.assertEqual(ret, True)
  55. ret = Rast_legal_semantic_label("S2_1")
  56. self.assertEqual(ret, True)
  57. ret = Rast_legal_semantic_label("GRASS_aspect_deg")
  58. self.assertEqual(ret, True)
  59. class Rastsemantic_labelerenceTestCase(TestCase):
  60. @classmethod
  61. def setUpClass(cls):
  62. cls.map = tempname(10)
  63. cls.mapset = Mapset().name
  64. cls.semantic_label = "The_Doors"
  65. cls.use_temp_region()
  66. cls.runModule("g.region", n=1, s=0, e=1, w=0, res=1)
  67. cls.runModule("r.mapcalc", expression="{} = 1".format(cls.map))
  68. @classmethod
  69. def tearDownClass(cls):
  70. cls.del_temp_region()
  71. cls.runModule("g.remove", flags="f", type="raster", name=cls.map)
  72. def test_read_semantic_label_present(self):
  73. Rast_write_semantic_label(self.map, self.semantic_label)
  74. ret = utils.decode(Rast_read_semantic_label(self.map, self.mapset))
  75. self.assertEqual(ret, self.semantic_label)
  76. def test_read_semantic_label_absent(self):
  77. G_remove_misc("cell_misc", "semantic_label", self.map)
  78. ret = Rast_read_semantic_label(self.map, self.mapset)
  79. self.assertFalse(bool(ret))
  80. def test_write_semantic_label(self):
  81. G_remove_misc("cell_misc", "semantic_label", self.map)
  82. Rast_write_semantic_label(self.map, self.semantic_label)
  83. ret = utils.decode(Rast_read_semantic_label(self.map, self.mapset))
  84. self.assertEqual(ret, self.semantic_label)
  85. def test_get_semantic_label_or_name(self):
  86. G_remove_misc("cell_misc", "semantic_label", self.map)
  87. ret = utils.decode(Rast_get_semantic_label_or_name(self.map, self.mapset))
  88. self.assertEqual(ret, self.map)
  89. Rast_write_semantic_label(self.map, self.semantic_label)
  90. ret = utils.decode(Rast_get_semantic_label_or_name(self.map, self.mapset))
  91. self.assertEqual(ret, self.semantic_label)
  92. if __name__ == "__main__":
  93. test()