예제 #1
0
def manualtest_ilismeta_from_xtf():
    loader = ModelLoader(
        "./tests/data/ch.bazl/ch.bazl.sicherheitszonenplan.oereb_20131118.xtf")
    outfile = loader.create_ilismeta_model()
    with open(outfile) as file:
        imd = file.read()
        assert '<IlisMeta07.ModelData.Class TID="OeREBKRM09trsfr.Transferstruktur.ZustaendigeStelleGeometrie">' in imd
예제 #2
0
def test_detect_models_ili2():
    loader = ModelLoader(
        "./tests/data/ch.bazl/ch.bazl.sicherheitszonenplan.oereb_20131118.xtf")
    models = loader.detect_models()
    names = map(lambda model: model.name, models)
    assert set(names) == {'OeREBKRM09trsfr', 'MultilingualText09', 'chGeoId10', 'CodeISO', 'OeREBKRM09vs', 'OeREBKRM09'}
    assert models[0].version == "20060808"
    assert models[0].uri == "http://www.kogis.ch"
예제 #3
0
def manualtest_model_conversion():
    loader = ModelLoader("")
    outfile = os.path.join(TEMPDIR, "tmpogrtools")
    loader.convert_model(["./tests/data/ili/Beispiel.ili"], outfile)
    with open(outfile) as file:
        imd = file.read()
        assert 'IlisMeta07.ModelData.EnumNode TID="Beispiel.Bodenbedeckung.BoFlaechen.Art.TYPE.TOP"' in imd

    loader.convert_model(["./tests/data/ili/Test23_erweitert.ili"], outfile)
    with open(outfile) as file:
        imd = file.read()
        assert 'IlisMeta07.ModelData.Class TID="Test23_erweitert.FixpunkteKategorie1.LFP1"' in imd
        # Does include Test23.ili as well:
        assert 'IlisMeta07.ModelData.NumType TID="Test23.Genauigkeit"' in imd
예제 #4
0
 def on_mCreateIlisMetaButton_clicked(self):
     loader = ModelLoader("")
     outfile = QFileDialog.getSaveFileName(
         None, "Save File", self.ui.mIliLineEdit.text(),
         "IlisMeta model (*.imd *.IMD)")
     if not outfile:
         return
     os.environ['ILI2C'] = self.ui.mIli2cLineEdit.text()
     ret = loader.convert_model([self.ui.mIliLineEdit.text()], outfile)
     err = ("Error:" in ret)
     self._show_log_window()
     self._log_output("IlisMeta creation: " + str(ret))
     if not err:
         self.ui.mModelLineEdit.setText(outfile)
예제 #5
0
 def on_mModelLookupButton_clicked(self):
     imd = None
     try:
         loader = ModelLoader(self.ui.mDataLineEdit.text())
         models = loader.detect_models()
         model_names = map(lambda m: m.name, models)
         self._log_output("Looking up models: " + ', '.join(model_names))
         ili = loader.gen_lookup_ili()
         qDebug(ili)
         wpsreq = self._create_wps_request(ili)
         req = urllib2.Request(url="http://wps.sourcepole.ch/wps?",
                               data=wpsreq,
                               headers={'Content-Type': 'application/xml'})
         # TODO: proxy support
         response = urllib2.urlopen(req)  # timeout=int(TIMEOUT)
         result = response.read()
         imd = self._parse_wps_response(result)
     except urllib2.HTTPError, err:
         qDebug("HTTPError %d" % err.code)
예제 #6
0
def test_detect_ili1():
    loader = ModelLoader("./tests/data/ili/Beispiel.itf")
    assert loader.detect_format() == 'Interlis 1'
예제 #7
0
def test_lookup_ili():
    loader = ModelLoader("./tests/data/ili/roads23.xtf")
    assert "IMPORTS RoadsExdm2ben" in loader.gen_lookup_ili()
예제 #8
0
def test_detect_models_none():
    loader = ModelLoader("./tests/data/osm/railway.shp")
    assert loader.detect_models() is None
예제 #9
0
def test_detect_models_ili1():
    loader = ModelLoader("./tests/data/ili/Beispiel.itf")
    assert loader.detect_models()[0].name == 'Beispiel'
예제 #10
0
def test_detect_ili2():
    loader = ModelLoader(
        "./tests/data/ch.bazl/ch.bazl.sicherheitszonenplan.oereb_20131118.xtf")
    assert loader.detect_format() == 'Interlis 2'