123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- # -*- coding: utf-8 -*-
- """Test v.what.strds
- (C) 2014 by the GRASS Development Team
- This program is free software under the GNU General Public
- License (>=v2). Read the file COPYING that comes with GRASS
- for details.
- @author Luca Delucchi
- """
- from grass.gunittest.case import TestCase
- from grass.gunittest.main import test
- from grass.gunittest.gmodules import SimpleModule
- import grass.script as gscript
- from grass.script.utils import decode
- class TestWhatStrds(TestCase):
- @classmethod
- def setUpClass(cls):
- """Initiate the temporal GIS and set the region
- """
- cls.use_temp_region()
- cls.runModule("g.region", s=0, n=80, w=0, e=120, b=0, t=50,
- res=10, res3=10)
- cls.runModule("r.mapcalc", expression="a_1 = 100", overwrite=True)
- cls.runModule("r.mapcalc", expression="a_2 = 200", overwrite=True)
- cls.runModule("r.mapcalc", expression="a_3 = 300", overwrite=True)
- cls.runModule("r.mapcalc", expression="a_4 = 400", overwrite=True)
- cls.runModule("v.random", output="points", npoints=3, seed=1,
- overwrite=True)
- cls.runModule("t.create", type="strds", temporaltype="absolute",
- output="A", title="A test", description="A test",
- overwrite=True)
- cls.runModule("t.register", flags="i", type="raster", input="A",
- maps="a_1,a_2,a_3,a_4", start="2001-01-01",
- increment="3 months", overwrite=True)
- @classmethod
- def tearDownClass(cls):
- """Remove the temporary region
- """
- cls.runModule("t.remove", flags="rf", type="strds", inputs="A")
- cls.del_temp_region()
- def test_output(self):
- self.assertModule("v.what.strds", input="points", strds="A",
- output="what_strds", overwrite=True)
- maps = gscript.list_strings('vector')
- self.assertIn('what_strds@{ma}'.format(ma=gscript.gisenv()['MAPSET']),
- maps)
- def test_values(self):
- self.assertModule("v.what.strds", input="points", strds="A",
- output="what_strds", overwrite=True)
- db_sel = SimpleModule("v.db.select", map="what_strds")
- self.assertModule(db_sel)
- output = """cat|A_2001_01_01|A_2001_04_01|A_2001_07_01|A_2001_10_01
- 1|100|200|300|400
- 2|100|200|300|400
- 3|100|200|300|400
- """
- self.assertMultiLineEqual(output, decode(db_sel.outputs.stdout))
- if __name__ == '__main__':
- test()
|