From 493589aaf1bc2ba6de14ed934022a83d5caf2ab6 Mon Sep 17 00:00:00 2001 From: amercader Date: Mon, 25 Jun 2012 19:27:18 +0100 Subject: [PATCH 1/3] [#2399] Fixes for CKAN 1.8 * Fix broken imports in model after cleanup * Minor CSS glitch on the spatial filter widget --- ckanext/spatial/model.py | 18 +++++++++++------- .../spatial/css/spatial_search_form.css | 2 +- 2 files changed, 12 insertions(+), 8 deletions(-) diff --git a/ckanext/spatial/model.py b/ckanext/spatial/model.py index 5144602..3dc3942 100644 --- a/ckanext/spatial/model.py +++ b/ckanext/spatial/model.py @@ -1,12 +1,16 @@ from logging import getLogger +from sqlalchemy import types, Column, Table + +from geoalchemy import Geometry, GeometryColumn, GeometryDDL, GeometryExtensionColumn +from geoalchemy.postgis import PGComparator + + from ckan.lib.base import config from ckan import model from ckan.model import Session -from ckan.model.meta import * +from ckan.model import meta from ckan.model.domain_object import DomainObject -from geoalchemy import * -from geoalchemy.postgis import PGComparator log = getLogger(__name__) @@ -21,8 +25,8 @@ def setup(srid=None): log.debug('Spatial tables defined in memory') if model.repo.are_tables_created(): - if not Table('geometry_columns',metadata).exists() or \ - not Table('spatial_ref_sys',metadata).exists(): + if not Table('geometry_columns',meta.metadata).exists() or \ + not Table('spatial_ref_sys',meta.metadata).exists(): raise Exception('The spatial extension is enabled, but PostGIS ' + \ 'has not been set up in the database. ' + \ 'Please refer to the "Setting up PostGIS" section in the README.') @@ -63,12 +67,12 @@ def define_spatial_tables(db_srid=None): else: db_srid = int(db_srid) - package_extent_table = Table('package_extent', metadata, + package_extent_table = Table('package_extent', meta.metadata, Column('package_id', types.UnicodeText, primary_key=True), GeometryExtensionColumn('the_geom', Geometry(2,srid=db_srid))) - mapper(PackageExtent, package_extent_table, properties={ + meta.mapper(PackageExtent, package_extent_table, properties={ 'the_geom': GeometryColumn(package_extent_table.c.the_geom, comparator=PGComparator)}) diff --git a/ckanext/spatial/public/ckanext/spatial/css/spatial_search_form.css b/ckanext/spatial/public/ckanext/spatial/css/spatial_search_form.css index 2f8a9f3..f89afba 100644 --- a/ckanext/spatial/public/ckanext/spatial/css/spatial_search_form.css +++ b/ckanext/spatial/public/ckanext/spatial/css/spatial_search_form.css @@ -1,5 +1,5 @@ #spatial-search-show{ - margin-top: 10px; + margin-top: 40px; } #spatial-search-show a.more:after { From 9bc3759bd11b99721a3561d9db28c440a957f78a Mon Sep 17 00:00:00 2001 From: amercader Date: Thu, 12 Jul 2012 19:13:21 +0100 Subject: [PATCH 2/3] Update tests for auth changes in core (#2388) --- ckanext/spatial/tests/test_dataset_map.py | 7 ++++--- ckanext/spatial/tests/test_functional.py | 25 ++++++++++++++--------- 2 files changed, 19 insertions(+), 13 deletions(-) diff --git a/ckanext/spatial/tests/test_dataset_map.py b/ckanext/spatial/tests/test_dataset_map.py index 4e77109..8815563 100644 --- a/ckanext/spatial/tests/test_dataset_map.py +++ b/ckanext/spatial/tests/test_dataset_map.py @@ -16,18 +16,19 @@ class TestDatasetMap(FunctionalTestCase,SpatialTestBase): def test_map_shown(self): CreateTestData.create() - + + extra_environ = {'REMOTE_USER': 'annafan'} name = 'annakarenina' offset = url_for(controller='package', action='edit',id=name) - res = self.app.get(offset) + res = self.app.get(offset, extra_environ=extra_environ) assert 'Edit - Datasets' in res fv = res.forms['dataset-edit'] prefix = '' fv[prefix+'extras__1__key'] = u'spatial' fv[prefix+'extras__1__value'] = self.geojson_examples['point'] - res = fv.submit('save') + res = fv.submit('save', extra_environ=extra_environ) assert not 'Error' in res, res # Load the dataset page and check if the libraries have been loaded diff --git a/ckanext/spatial/tests/test_functional.py b/ckanext/spatial/tests/test_functional.py index 5c3de81..2e29aa9 100644 --- a/ckanext/spatial/tests/test_functional.py +++ b/ckanext/spatial/tests/test_functional.py @@ -14,6 +14,11 @@ log = logging.getLogger(__name__) class TestPackageController(FunctionalTestCase,SpatialTestBase): + + @classmethod + def setup_class(cls): + cls.extra_environ = {'REMOTE_USER': 'annafan'} + def setup(self): CreateTestData.create() @@ -24,7 +29,7 @@ class TestPackageController(FunctionalTestCase,SpatialTestBase): name = 'test-spatial-dataset-1' offset = url_for(controller='package', action='new') - res = self.app.get(offset) + res = self.app.get(offset, extra_environ=self.extra_environ) assert 'Add - Datasets' in res fv = res.forms['dataset-edit'] prefix = '' @@ -32,7 +37,7 @@ class TestPackageController(FunctionalTestCase,SpatialTestBase): fv[prefix+'extras__0__key'] = u'spatial' fv[prefix+'extras__0__value'] = self.geojson_examples['point'] - res = fv.submit('save') + res = fv.submit('save', extra_environ=self.extra_environ) assert not 'Error' in res, res package = Package.get(name) @@ -52,7 +57,7 @@ class TestPackageController(FunctionalTestCase,SpatialTestBase): name = 'test-spatial-dataset-2' offset = url_for(controller='package', action='new') - res = self.app.get(offset) + res = self.app.get(offset, extra_environ=self.extra_environ) assert 'Add - Datasets' in res fv = res.forms['dataset-edit'] prefix = '' @@ -60,7 +65,7 @@ class TestPackageController(FunctionalTestCase,SpatialTestBase): fv[prefix+'extras__0__key'] = u'spatial' fv[prefix+'extras__0__value'] = u'{"Type":Bad Json]' - res = fv.submit('save') + res = fv.submit('save', extra_environ=self.extra_environ) assert 'Error' in res, res assert 'Spatial' in res assert 'Error decoding JSON object' in res @@ -72,7 +77,7 @@ class TestPackageController(FunctionalTestCase,SpatialTestBase): name = 'test-spatial-dataset-3' offset = url_for(controller='package', action='new') - res = self.app.get(offset) + res = self.app.get(offset, extra_environ=self.extra_environ) assert 'Add - Datasets' in res fv = res.forms['dataset-edit'] prefix = '' @@ -80,7 +85,7 @@ class TestPackageController(FunctionalTestCase,SpatialTestBase): fv[prefix+'extras__0__key'] = u'spatial' fv[prefix+'extras__0__value'] = u'{"Type":"Bad_GeoJSON","a":2}' - res = fv.submit('save') + res = fv.submit('save', extra_environ=self.extra_environ) assert 'Error' in res, res assert 'Spatial' in res assert 'Error creating geometry' in res @@ -93,14 +98,14 @@ class TestPackageController(FunctionalTestCase,SpatialTestBase): name = 'annakarenina' offset = url_for(controller='package', action='edit',id=name) - res = self.app.get(offset) + res = self.app.get(offset, extra_environ=self.extra_environ) assert 'Edit - Datasets' in res fv = res.forms['dataset-edit'] prefix = '' fv[prefix+'extras__1__key'] = u'spatial' fv[prefix+'extras__1__value'] = self.geojson_examples['point'] - res = fv.submit('save') + res = fv.submit('save', extra_environ=self.extra_environ) assert not 'Error' in res, res package = Package.get(name) @@ -117,13 +122,13 @@ class TestPackageController(FunctionalTestCase,SpatialTestBase): # Update the spatial extra offset = url_for(controller='package', action='edit',id=name) - res = self.app.get(offset) + res = self.app.get(offset, extra_environ=self.extra_environ) assert 'Edit - Datasets' in res fv = res.forms['dataset-edit'] prefix = '' fv[prefix+'extras__1__value'] = self.geojson_examples['polygon'] - res = fv.submit('save') + res = fv.submit('save', extra_environ=self.extra_environ) assert not 'Error' in res, res # Check that the PackageExtent object has been updated From b784be8f9e4c80f8d2ce45ed90a84797d04ecb4c Mon Sep 17 00:00:00 2001 From: amercader Date: Thu, 9 Aug 2012 11:02:13 +0100 Subject: [PATCH 3/3] Do not use repo.are_tables_created When checking whether the core tables have been alredy created it is best to use package_table.exists(), as are_tables_created reflects the tables, causing conflicts with other extensions. This allows ckanext-harvest and ckanext-spatial to be used together on ckan 1.8 onwards. --- ckanext/spatial/model.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ckanext/spatial/model.py b/ckanext/spatial/model.py index 3dc3942..908dcd8 100644 --- a/ckanext/spatial/model.py +++ b/ckanext/spatial/model.py @@ -24,7 +24,7 @@ def setup(srid=None): define_spatial_tables(srid) log.debug('Spatial tables defined in memory') - if model.repo.are_tables_created(): + if model.package_table.exists(): if not Table('geometry_columns',meta.metadata).exists() or \ not Table('spatial_ref_sys',meta.metadata).exists(): raise Exception('The spatial extension is enabled, but PostGIS ' + \