Add tests for each module

pull/347/head
Dakota Benjamin 2016-03-15 10:20:54 -04:00
rodzic c40330cb18
commit cd6912af98
1 zmienionych plików z 134 dodań i 30 usunięć

Wyświetl plik

@ -1,46 +1,150 @@
import unittest
import os
import shutil
import ecto
from opendm import config
from opendm import context
import ecto
from scripts.odm_app import ODMApp
from ecto.opts import scheduler_options, run_plasm
#
parser = config.parser
scheduler_options(parser)
options = config.config()
def appSetup(options):
app = ODMApp(args=options)
plasm = ecto.Plasm()
plasm.insert(app)
return app, plasm
def setup_module():
# Run tests
print '%s' % options
options.project_path = context.tests_data_path
# options.rerun_all = True
app, plasm = appSetup(options)
print 'Run Setup: Initial Run'
run_plasm(options, plasm)
# options.rerun_all = False
def teardown_module():
# Delete generated test directories
dirnames = ['images_resize', 'opensfm', 'pmvs', 'odm_meshing',
'odm_texturing', 'odm_georeferencing', 'odm_orthophoto']
for n in dirnames:
rmpath = os.path.join(context.tests_data_path, n)
if os.path.exists(rmpath):
shutil.rmtree(rmpath)
class TestResize(unittest.TestCase):
'''
"""
Tests the resize function
'''
"""
def setUp(self):
# Run tests
self.parser = config.parser
scheduler_options(self.parser)
self.options = self.parser.parse_args()
self.options.project_path = context.tests_data_path
self.app, self.plasm = self.appSetup(self.options)
print 'Run Setup: Initial Run'
run_plasm(self.options, self.plasm)
# rerun resize cell and set params
options.rerun = 'resize'
options.resize_to = 1600
# rebuild app
self.app, self.plasm = appSetup(options)
run_plasm(options, self.plasm)
def test_resize(self):
# rerun resize cell and set params
self.options.rerun = 'resize'
self.options.resize_to = 1600
print "Run Test 1: Rerun resize: %s" % self.options.resize_to
# rebuild app
self.app, self.plasm = self.appSetup(self.options)
run_plasm(self.options, self.plasm)
# assert each image is sized to the option.resize_to
print "Run Test 1: Check that the resize happens"
if self.app.resize.outputs.photos[0].height > self.app.resize.outputs.photos[0].width:
self.assertEquals(self.app.resize.outputs.photos[0].height, self.options.resize_to)
else:
self.assertEquals(self.app.resize.outputs.photos[0].width, self.options.resize_to)
self.assertEquals(max(self.app.resize.outputs.photos[0].height, self.app.resize.outputs.photos[0].width),
options.resize_to)
def test_all_resized(self):
# assert the number of images in images == number of images in resize
self.assertEquals(len(self.app.resize.outputs.photos), len(self.app.dataset.outputs.photos))
def appSetup(self, options):
app = ODMApp(args=vars(options))
plasm = ecto.Plasm()
plasm.insert(app)
return app, plasm
class TestOpenSfM(unittest.TestCase):
"""
Tests the OpenSfM module
"""
def setUp(self):
options.rerun = 'opensfm'
self.app, self.plasm = appSetup(options)
run_plasm(options, self.plasm)
def test_opensfm(self):
# Test configuration
self.assertTrue(os.path.isfile(self.app.opensfm.inputs.tree.opensfm_reconstruction))
class TestCMVS(unittest.TestCase):
def setUp(self):
options.rerun = 'cmvs'
self.app, self.plasm = appSetup(options)
run_plasm(options, self.plasm)
def test_cmvs(self):
self.assertTrue(os.path.isfile(self.app.cmvs.inputs.tree.pmvs_bundle))
class TestPMVS(unittest.TestCase):
def setUp(self):
options.rerun = 'pmvs'
self.app, self.plasm = appSetup(options)
run_plasm(options, self.plasm)
def test_pmvs(self):
self.assertTrue(os.path.isfile(self.app.pmvs.inputs.tree.pmvs_model))
class TestMeshing(unittest.TestCase):
def setUp(self):
options.rerun = 'odm_meshing'
self.app, self.plasm = appSetup(options)
run_plasm(options, self.plasm)
def test_meshing(self):
self.assertTrue(os.path.isfile(self.app.meshing.inputs.tree.odm_mesh))
class TestTexturing(unittest.TestCase):
def setUp(self):
options.rerun = 'odm_texturing'
self.app, self.plasm = appSetup(options)
run_plasm(options, self.plasm)
def test_texturing(self):
self.assertTrue(os.path.isfile(self.app.texturing.inputs.tree.odm_textured_model_obj))
class TestGeoreferencing(unittest.TestCase):
def setUp(self):
options.rerun = 'odm_georeferencing'
self.app, self.plasm = appSetup(options)
run_plasm(options, self.plasm)
def test_georef(self):
self.assertTrue(os.path.isfile(self.app.georeferencing.inputs.tree.odm_georeferencing_coords) &
os.path.isfile(self.app.georeferencing.inputs.tree.odm_georeferencing_model_obj_geo))
class TestOrthophoto(unittest.TestCase):
def setUp(self):
options.rerun = 'odm_orthophoto'
self.app, self.plasm = appSetup(options)
run_plasm(options, self.plasm)
def test_orthophoto(self):
self.assertTrue(os.path.isfile(self.app.orthophoto.inputs.tree.odm_orthophoto_file))
if __name__ == '__main__':
unittest.main()
unittest.main()