#!/usr/bin/env python2.7 # -*- coding: utf-8 -*- # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # MapServer REST API is a python wrapper around MapServer which # # allows to manipulate a mapfile in a RESTFul way. It has been # # developped to match as close as possible the way the GeoServer # # REST API acts. # # # # Copyright (C) 2011-2013 Neogeo Technologies. # # # # This file is part of MapServer Rest API. # # # # MapServer Rest API is free software: you can redistribute it # # and/or modify it under the terms of the GNU General Public License # # as published by the Free Software Foundation, either version 3 of # # the License, or (at your option) any later version. # # # # MapServer Rest API is distributed in the hope that it will be # # useful, but WITHOUT ANY WARRANTY; without even the implied warranty # # of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # # GNU General Public License for more details. # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # from utils import APIRequest import sys def test_scenario(): target = "http://localhost:8080" map_name = "tests" # Clean the test file, now we are sure it is empty. APIRequest("PUT", target + "/tests/" + map_name) # GET workspaces. wss = APIRequest("GET", target + "/maps/" + map_name + "/workspaces")["workspaces"] assert len(wss) == 1 assert wss[0]["name"] == "default" # GET workspaceName ws = APIRequest("GET", wss[0]["href"])["workspace"] assert ws["name"] == wss[0]["name"] # GET dataStores dss = APIRequest("GET", ws["dataStores"]["href"])["dataStores"] assert len(dss) == 0 # POST a datastore and GET it name, title = "testDS1", "test datastore 1" _, r = APIRequest("POST", ws["dataStores"]["href"], {"dataStore":{"name":name, "title":title}}, get_response=True) ds_link = r.getheader("Location") ds = APIRequest("GET", ds_link)["dataStore"] assert ds["name"] == name assert ds["title"] == title # PUT a datastore ds["title"] = title.upper() del ds["href"] APIRequest("PUT", ds_link, {"dataStore":ds}) ds = APIRequest("GET", ds_link)["dataStore"] assert ds["title"] == title.upper() # GET featuretypes fts = APIRequest("GET", ds["href"])["featureTypes"] assert len(fts) == 0 # PUT file, and check if datastore is updated. APIRequest("PUT", ds_link + "/file.shp", open("./files/timezones_shp.zip", "rb"), encode=None, content_type="application/zip") ds = APIRequest("GET", ds_link)["dataStore"] assert ds["connectionParameters"]["url"] == "file:/workspaces/%s/datastores/%s/timezones.shp" % (ws["name"], ds["name"]) # POST a featuretype name, title = "testFT1", "test feature type 1" _, r = APIRequest("POST", ds["href"], {"featureType":{"name":name, "title":title}}, get_response=True) ft_link = r.getheader("Location") ft = APIRequest("GET", ft_link)["featureType"] assert ft["name"] == name assert ds["title"] == title