2019-06-20 19:39:49 +00:00
|
|
|
import time
|
|
|
|
import unittest
|
|
|
|
import os
|
2019-06-21 17:14:44 +00:00
|
|
|
import shutil
|
|
|
|
|
2019-06-20 19:39:49 +00:00
|
|
|
from opendm.gcp import GCPFile
|
|
|
|
|
2019-06-21 17:14:44 +00:00
|
|
|
|
|
|
|
class TestGcp(unittest.TestCase):
|
2019-06-20 19:39:49 +00:00
|
|
|
def setUp(self):
|
2019-06-21 17:14:44 +00:00
|
|
|
if os.path.exists("tests/assets/output"):
|
|
|
|
shutil.rmtree("tests/assets/output")
|
|
|
|
os.makedirs("tests/assets/output")
|
|
|
|
# pass
|
|
|
|
|
2019-06-20 19:39:49 +00:00
|
|
|
def test_utm_north(self):
|
|
|
|
gcp = GCPFile("tests/assets/gcp_utm_north_valid.txt")
|
|
|
|
self.assertTrue(gcp.exists())
|
|
|
|
self.assertEqual(gcp.wgs84_utm_zone(), "WGS84 UTM 16N")
|
|
|
|
|
2019-06-21 17:14:44 +00:00
|
|
|
def test_latlon_south(self):
|
|
|
|
gcp = GCPFile("tests/assets/gcp_latlon_south.txt")
|
|
|
|
self.assertTrue(gcp.exists())
|
|
|
|
self.assertEqual(gcp.wgs84_utm_zone(), "WGS84 UTM 48S")
|
|
|
|
|
|
|
|
def test_latlon(self):
|
|
|
|
gcp = GCPFile("tests/assets/gcp_latlon_valid.txt")
|
2019-06-20 19:39:49 +00:00
|
|
|
self.assertTrue(gcp.exists())
|
|
|
|
self.assertEqual(gcp.wgs84_utm_zone(), "WGS84 UTM 16N")
|
|
|
|
|
2019-06-21 17:14:44 +00:00
|
|
|
def test_utm_conversion(self):
|
|
|
|
gcp = GCPFile("tests/assets/gcp_latlon_valid.txt")
|
|
|
|
copy = GCPFile(gcp.create_utm_copy("tests/assets/output/gcp_utm.txt"))
|
|
|
|
self.assertTrue(copy.exists())
|
|
|
|
self.assertEqual(copy.raw_srs, "WGS84 UTM 16N")
|
2020-09-08 17:08:57 +00:00
|
|
|
self.assertEqual(copy.get_entry(0).x, 609865.7077054137)
|
|
|
|
self.assertEqual(copy.get_entry(0).y, 4950688.361817497)
|
2019-06-21 17:14:44 +00:00
|
|
|
|
|
|
|
def test_utm_conversion_feet(self):
|
|
|
|
gcp = GCPFile("tests/assets/gcp_michigan_feet_valid.txt")
|
|
|
|
copy = GCPFile(gcp.create_utm_copy("tests/assets/output/gcp_utm_z.txt"))
|
|
|
|
self.assertTrue(copy.exists())
|
|
|
|
self.assertEqual(copy.raw_srs, "WGS84 UTM 16N")
|
|
|
|
self.assertEqual(round(copy.get_entry(0).x, 3), 609925.818)
|
|
|
|
self.assertEqual(round(copy.get_entry(0).y, 3), 4950688.772)
|
2020-09-08 17:08:57 +00:00
|
|
|
self.assertEqual(round(copy.get_entry(0).z, 3), 563.199)
|
2019-06-21 17:14:44 +00:00
|
|
|
|
|
|
|
def test_filtered_copy(self):
|
|
|
|
gcp = GCPFile('tests/assets/gcp_latlon_valid.txt')
|
|
|
|
self.assertTrue(gcp.exists())
|
|
|
|
self.assertEqual(gcp.entries_count(), 2)
|
|
|
|
copy = GCPFile(gcp.make_filtered_copy('tests/assets/output/filtered_copy.txt', 'tests/assets/images', min_images=1))
|
|
|
|
self.assertTrue(copy.exists())
|
|
|
|
self.assertEqual(copy.entries_count(), 1)
|
|
|
|
|
2019-06-21 19:33:10 +00:00
|
|
|
def test_null_gcp(self):
|
|
|
|
gcp = GCPFile(None)
|
|
|
|
self.assertFalse(gcp.exists())
|
|
|
|
|
2019-06-24 12:28:44 +00:00
|
|
|
def test_gcp_extras(self):
|
|
|
|
gcp = GCPFile('tests/assets/gcp_extras.txt')
|
|
|
|
self.assertEqual(gcp.get_entry(0).extras, 'gcp1')
|
|
|
|
|
|
|
|
copy = GCPFile(gcp.create_utm_copy("tests/assets/output/gcp_utm_no_extras.txt", include_extras=False))
|
|
|
|
self.assertTrue(copy.exists())
|
|
|
|
self.assertEqual(copy.get_entry(0).extras, '')
|
|
|
|
|
2019-06-20 19:39:49 +00:00
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|