def test_create(self): """POST /mapfiles: Create a new item.""" # login as admin to be allowed to access /mapfiles/1 log_in(self.app, 'enduser', 'password') mapfile = Mapfile() mapfile.from_file(os.path.join(config['mapserver_dir'], 'dummy_mapfile.map')) mapfile.set_name('Dummy mapfile name') mapfile = change_mapfile_paths(mapfile) dict = mapfile.to_dict() content = simplejson.dumps(dict) # post create request that must be tested response = self.app.post(url('mapfiles'), params=content, content_type='application/json') dict = simplejson.loads(response.normal_body) print os.path.join(config['mapfiles_dir'], dict['name']) map = model.meta.Session.query(model.Map).filter(model.Map.name=='Dummy mapfile name').one() assert map.id == dict['id'] assert map.name == dict['name'] assert os.path.exists(os.path.join(config['mapfiles_dir'], map.filepath)) # test redirection to /signin when log out log_out(self.app) response = self.app.post(url('mapfiles'), params=content, content_type='application/json', status=302) urlparsed = urlparse(response.location) assert urlparsed.path == '/signin' # we are redirected to "signin" # Clean the mapfile created by POST request delete_mapfile(map)
def get_symbols(self,id): map = self._get_map_from_user_by_id(c.user, id) if map is None: abort(404) mapfile = Mapfile() mapfile.from_file(os.path.join(config['mapfiles_dir'], map.filepath)) # prevent JSON Array Cross-site Exploits (XSRF/CSRF) return {'symbols': mapfile.get_symbols()}
def get_symbols(self, id): map = self._get_map_from_user_by_id(c.user, id) if map is None: abort(404) mapfile = Mapfile() mapfile.from_file(os.path.join(config['mapfiles_dir'], map.filepath)) # prevent JSON Array Cross-site Exploits (XSRF/CSRF) return {'symbols': mapfile.get_symbols()}
def show(self, id): """ GET /mapfiles/id: Get a specific mapfile owned by the current user. """ map = self._get_map_from_user_by_id(c.user, id) if map is None: abort(404) mapfile = Mapfile() mapfile.from_file(os.path.join(config['mapfiles_dir'], map.filepath)) return { 'map': mapfile.to_dict(), 'wmsproxyurl': h.url_for(controller='mapfiles', action='wms_proxy', id=id), 'wmsurl': "%s?%s" %(config['mapserver_url'], urlencode({'map':os.path.join(config['mapfiles_dir'], map.filepath)})) }
def create_mapfile(mapfile_name, pathname, user_id=2): # copy test mapfile dummy_mapfile.map and change fontset and symbolset paths # so that it matches user environnement mapfile = Mapfile() mapfile.from_file(os.path.join(config['mapserver_dir'], 'dummy_mapfile.map')) mapfile.set_name(mapfile_name) mapfile = change_mapfile_paths(mapfile) mapfile.to_file(os.path.join(config['mapfiles_dir'], pathname)) assert os.path.exists(os.path.join(config['mapfiles_dir'], pathname)) # db insertion of new mapfile map = Map(mapfile_name, pathname, user_id) meta.Session.add(map) meta.Session.commit() return map
def show(self, id): """ GET /mapfiles/id: Get a specific mapfile owned by the current user. """ map = self._get_map_from_user_by_id(c.user, id) if map is None: abort(404) mapfile = Mapfile() mapfile.from_file(os.path.join(config['mapfiles_dir'], map.filepath)) return { 'map': mapfile.to_dict(), 'wmsproxyurl': h.url_for(controller='mapfiles', action='wms_proxy', id=id), 'wmsurl': "%s?%s" % (config['mapserver_url'], urlencode( {'map': os.path.join(config['mapfiles_dir'], map.filepath)})) }
def test_update(self): """PUT /mapfiles/id: Update an existing item.""" # Create new mapfile for this test filename = h.gen_mapname() map = create_mapfile('Dummy mapfile name', filename) # login as admin to be allowed to access /mapfiles/1 log_in(self.app, 'enduser', 'password') mapfile = Mapfile() mapfile.from_file(os.path.join(config['mapserver_dir'], 'dummy_mapfile.map')) mapfile.set_name('New dummy name') mapfile = change_mapfile_paths(mapfile) dict = mapfile.to_dict() content = simplejson.dumps(dict) # PUT update request that must be tested map_id = map.id response = self.app.put(url('MapFiles', id=map_id), params=content, content_type='application/json') updated_map = model.meta.Session.query(model.Map).get(map_id) assert updated_map.name == 'New dummy name' map_path = os.path.join(config['mapfiles_dir'],updated_map.filepath) assert os.path.exists(map_path) mapobj = Mapfile() mapobj.from_file(map_path) assert mapobj.get_name() == 'New dummy name' # test redirection to /signin when log out log_out(self.app) response = self.app.get(url('MapFiles', id=map_id), params=content, status=302) urlparsed = urlparse(response.location) assert urlparsed.path == '/signin' # we are redirected to "signin" # Clean the test mapfile delete_mapfile(updated_map)