def test_cset_filter1_and_backend3(self, OsmApi, Poly, FileWriter, IsFile, Listdir, Remove, OsCset, Os): '''Verify generation of map center for index.html. Based on center of polygon specified in environment variable overriding config file ''' IsFile.return_value = True Listdir.return_value = self.listdir OsmApi.return_value = self.osmapi Poly.return_value.contains_chgset.return_value = True Poly.return_value.center.return_value = (11,56) FileWriter.side_effect = self.fstart Os.environ = {'OSMTRACKER_REGION': 'region-from-env.poly', 'OSMTRACKER_MAP_SCALE': '4'} OsCset.environ = {'OSMTRACKER_REGION': 'region-from-env2.poly'} osmtracker.csets_filter(None, self.cfg, self.db) osmtracker.csets_analyze_initial(None, self.cfg, self.db) osmtracker.csets_analyze_on_close(None, self.cfg, self.db) self.cfg.cfg['backends'][6]['map_center'] = {'area_file_conversion_type': 'area_center', 'area_file': 'region-not-used.poly'} osmtracker.run_backends(None, self.cfg, self.db) self.assertTrue('html/index.html' in self.files) #self.print_file('html/index.html') self.assertTrue('setView(new L.LatLng(56,11),4)' in self.files['html/index.html']) #print 'Poly mock calls', Poly.mock_calls Poly.assert_has_calls([call().load('region-from-env.poly')]) Poly.assert_has_calls([call().load('region-from-env2.poly')]) self.assertFalse(call().load('region.poly') in Poly.mock_calls)
def test_cset_filter2(self, OsmApi, Poly): '''Cset has single label, filter list have two elements, test that cset is dropped since it does not have both from filter list ''' OsmApi.return_value = self.osmapi Poly.return_value.contains_chgset.return_value = False osmtracker.csets_filter(None, self.cfg, self.db) self.assertTrue(len(self.db.csets)==0) # Filtered out since list is logical AND
def test_cset_filter2(self, OsmApi, Poly): '''Cset has single label, filter list have two elements, test that cset is dropped since it does not have both from filter list ''' OsmApi.return_value = self.osmapi Poly.return_value.contains_chgset.return_value = False osmtracker.csets_filter(None, self.cfg, self.db) self.assertTrue(len(self.db.csets)==0) # Filtered out since list is logical AND
def test_cset_filter3(self, OsmApi, Poly): '''Cset has single label, filter list have single element, test that cset is kept. ''' OsmApi.return_value = self.osmapi Poly.return_value.contains_chgset.return_value = False self.cfg.cfg['tracker']['prefilter_labels'] = [["adjustments"]] osmtracker.csets_filter(None, self.cfg, self.db) self.assertTrue(len(self.db.csets)==1)
def test_cset_filter3(self, OsmApi, Poly): '''Cset has single label, filter list have single element, test that cset is kept. ''' OsmApi.return_value = self.osmapi Poly.return_value.contains_chgset.return_value = False self.cfg.cfg['tracker']['prefilter_labels'] = [["adjustments"]] osmtracker.csets_filter(None, self.cfg, self.db) self.assertTrue(len(self.db.csets)==1)
def test_cset_filter4(self, OsmApi, Poly): '''Cset has single label, filter list have single elements, test that cset is kept. ''' OsmApi.return_value = self.osmapi Poly.return_value.contains_chgset.return_value = False self.cfg.cfg['tracker']['prefilter_labels'] = [["adjustmentsxx"], ['mapping-event']] self.cfg.cfg['tracker']['pre_labels'].append({"regex": [{".meta.tag.comment": ".*#\\w+"}], "label": "mapping-event"}) osmtracker.csets_filter(None, self.cfg, self.db) self.assertTrue(len(self.db.csets)==1)
def test_cset_filter4(self, OsmApi, Poly): '''Cset has single label, filter list have single elements, test that cset is kept. ''' OsmApi.return_value = self.osmapi Poly.return_value.contains_chgset.return_value = False self.cfg.cfg['tracker']['prefilter_labels'] = [["adjustmentsxx"], ['mapping-event']] self.cfg.cfg['tracker']['pre_labels'].append({"regex": [{".meta.tag.comment": ".*#\\w+"}], "label": "mapping-event"}) osmtracker.csets_filter(None, self.cfg, self.db) self.assertTrue(len(self.db.csets)==1)
def test_cset_filter1_and_backend(self, OsmApi, Poly, FileWriter, IsFile, Listdir, Remove): IsFile.return_value = True Listdir.return_value = self.listdir OsmApi.return_value = self.osmapi Poly.return_value.contains_chgset.return_value = True FileWriter.side_effect = self.fstart osmtracker.csets_filter(None, self.cfg, self.db) self.assertEqual(self.db.csets[0]['state'], self.db.STATE_BOUNDS_CHECKED) osmtracker.csets_analyze_initial(None, self.cfg, self.db) osmtracker.csets_analyze_on_close(None, self.cfg, self.db) #print 'DB:{}'.format(pprint.pformat(self.db.csets)) self.cfg.cfg['backends'][0]['labels'] = ['adjustments'] osmtracker.run_backends(None, self.cfg, self.db) #print 'files:', self.files.keys() #print 'xx', FileWriter.mock_calls #self.print_file('html/dynamic/today.html') #self.print_file('html/dynamic/dk_addresses.html') #self.print_file('html/dynamic/today-summ.html') #print 'filemocks', self.filemocks[0].mock_calls self.assertTrue('html/index.html' in self.files) self.assertTrue('html/dynamic/dk_addresses.html' in self.files) self.assertTrue('html/dynamic/today-summ.html' in self.files) self.assertTrue('html/dynamic/today.html' in self.files) self.assertTrue('html/dynamic/today.json' in self.files) self.assertTrue('html/dynamic/notes.html' in self.files) self.assertTrue('setView(new L.LatLng(56.0, 11.4),6)' in self.files['html/index.html']) self.assertTrue('No changesets' not in self.files['html/dynamic/today.html']) self.assertTrue('-- Changeset 10 source' in self.files['html/dynamic/today.html']) self.assertTrue('Total navigable: 12,888 meters (6,444m/hour)' in self.files['html/dynamic/today-summ.html']) self.assertTrue('1 changesets by 1 user' in self.files['html/dynamic/today-summ.html']) #print 'Remove mock calls', Remove.mock_calls Remove.assert_has_calls([call('html/dynamic/cset-3.json'), call('html/dynamic/cset-3.bounds')]) self.assertEqual(len(Remove.mock_calls), 2) # Rerun with non-matching labels self.cfg.cfg['backends'][0]['labels'] = ['xxadjustments'] osmtracker.run_backends(None, self.cfg, self.db) #self.print_file('html/dynamic/today.html') self.assertTrue('No changesets' in self.files['html/dynamic/today.html']) self.assertTrue('html/dynamic/cset-10.json' in self.files) #self.print_file('html/dynamic/cset-10.json') self.assertTrue('FeatureCollection' in self.files['html/dynamic/cset-10.json']) self.assertTrue('html/dynamic/cset-10.bounds' in self.files) #self.print_file('html/dynamic/cset-10.bounds') self.assertTrue('5,7,10,14' in self.files['html/dynamic/cset-10.bounds'])
def test_cset_filter1_and_backend(self, OsmApi, Poly, FileWriter, IsFile, Listdir, Remove): IsFile.return_value = True Listdir.return_value = self.listdir OsmApi.return_value = self.osmapi Poly.return_value.contains_chgset.return_value = True FileWriter.side_effect = self.fstart osmtracker.csets_filter(None, self.cfg, self.db) self.assertEqual(self.db.csets[0]['state'], self.db.STATE_BOUNDS_CHECKED) osmtracker.csets_analyze_initial(None, self.cfg, self.db) osmtracker.csets_analyze_on_close(None, self.cfg, self.db) #print 'DB:{}'.format(pprint.pformat(self.db.csets)) self.cfg.cfg['backends'][0]['labels'] = ['adjustments'] osmtracker.run_backends(None, self.cfg, self.db) #print 'files:', self.files.keys() #print 'xx', FileWriter.mock_calls #self.print_file('html/today.html') #self.print_file('html/dk_addresses.html') #self.print_file('html/today-summ.html') #print 'filemocks', self.filemocks[0].mock_calls self.assertTrue('No changesets' not in self.files['html/today.html']) self.assertTrue('-- Changeset 10 source' in self.files['html/today.html']) self.assertTrue('Total navigable: 12,888 meters (6,444m/hour)' in self.files['html/today-summ.html']) self.assertTrue('1 changesets by 1 user' in self.files['html/today-summ.html']) #print 'Remove mock calls', Remove.mock_calls Remove.assert_has_calls([call('html/cset-3.json'), call('html/cset-3.bounds')]) self.assertEqual(len(Remove.mock_calls), 2) # Rerun with non-matching labels self.cfg.cfg['backends'][0]['labels'] = ['xxadjustments'] osmtracker.run_backends(None, self.cfg, self.db) #self.print_file('html/today.html') self.assertTrue('No changesets' in self.files['html/today.html']) self.assertTrue('html/cset-10.json' in self.files) #self.print_file('html/cset-10.json') self.assertTrue('FeatureCollection' in self.files['html/cset-10.json']) self.assertTrue('html/cset-10.bounds' in self.files) #self.print_file('html/cset-10.bounds') self.assertTrue('5,7,10,14' in self.files['html/cset-10.bounds'])
def test_cset_filter1_and_backend2(self, OsmApi, Poly, FileWriter, IsFile, Listdir, Remove): '''Verify generation of map center for index.html. Based on center of polygon specified in config file ''' IsFile.return_value = True Listdir.return_value = self.listdir OsmApi.return_value = self.osmapi Poly.return_value.contains_chgset.return_value = True Poly.return_value.center.return_value = (11,56) FileWriter.side_effect = self.fstart osmtracker.csets_filter(None, self.cfg, self.db) osmtracker.csets_analyze_initial(None, self.cfg, self.db) osmtracker.csets_analyze_on_close(None, self.cfg, self.db) # Interpreted map_center config in index.html self.cfg.cfg['backends'][6]['map_center'] = {'area_file_conversion_type': 'area_center', 'area_file': 'region.poly'} osmtracker.run_backends(None, self.cfg, self.db) self.assertTrue('html/index.html' in self.files) self.assertTrue('setView(new L.LatLng(56,11),6)' in self.files['html/index.html']) Poly.assert_has_calls([call().load('region.poly')])