2013-07-29 19:19:04 +02:00
|
|
|
from __future__ import unicode_literals
|
2011-10-17 18:45:22 +00:00
|
|
|
|
2013-05-10 23:08:45 -04:00
|
|
|
from django.contrib.gis.geos import HAS_GEOS
|
2014-08-17 19:06:25 +02:00
|
|
|
from django.test import TestCase, override_settings, skipUnlessDBFeature
|
2011-10-17 18:45:22 +00:00
|
|
|
|
2014-08-17 19:06:25 +02:00
|
|
|
if HAS_GEOS:
|
2013-05-10 23:08:45 -04:00
|
|
|
from django.contrib.gis import admin
|
|
|
|
from django.contrib.gis.geos import Point
|
2011-10-17 18:45:22 +00:00
|
|
|
|
2014-08-04 11:14:45 -05:00
|
|
|
from .admin import UnmodifiableAdmin
|
2013-05-10 23:08:45 -04:00
|
|
|
from .models import City
|
2011-09-10 03:04:30 +00:00
|
|
|
|
2013-05-10 23:08:45 -04:00
|
|
|
|
2014-08-17 19:06:25 +02:00
|
|
|
@skipUnlessDBFeature("gis_enabled")
|
2014-04-05 11:34:46 +05:30
|
|
|
@override_settings(ROOT_URLCONF='django.contrib.gis.tests.geoadmin.urls')
|
2011-09-10 03:04:30 +00:00
|
|
|
class GeoAdminTest(TestCase):
|
|
|
|
|
2012-06-06 10:40:11 +02:00
|
|
|
def test_ensure_geographic_media(self):
|
2011-09-10 03:04:30 +00:00
|
|
|
geoadmin = admin.site._registry[City]
|
|
|
|
admin_js = geoadmin.media.render_js()
|
2013-08-29 19:20:00 -04:00
|
|
|
self.assertTrue(any(geoadmin.openlayers_url in js for js in admin_js))
|
2011-10-17 18:45:22 +00:00
|
|
|
|
2012-05-25 21:00:44 +02:00
|
|
|
def test_olmap_OSM_rendering(self):
|
2014-08-04 11:14:45 -05:00
|
|
|
delete_all_btn = """<a href="javascript:geodjango_point.clearFeatures()">Delete all Features</a>"""
|
|
|
|
|
|
|
|
original_geoadmin = admin.site._registry[City]
|
|
|
|
params = original_geoadmin.get_map_widget(City._meta.get_field('point')).params
|
|
|
|
result = original_geoadmin.get_map_widget(City._meta.get_field('point'))(
|
|
|
|
).render('point', Point(-79.460734, 40.18476), params)
|
2012-05-25 21:00:44 +02:00
|
|
|
self.assertIn(
|
|
|
|
"""geodjango_point.layers.base = new OpenLayers.Layer.OSM("OpenStreetMap (Mapnik)");""",
|
|
|
|
result)
|
|
|
|
|
2014-08-04 11:14:45 -05:00
|
|
|
self.assertIn(delete_all_btn, result)
|
|
|
|
|
|
|
|
admin.site.unregister(City)
|
|
|
|
admin.site.register(City, UnmodifiableAdmin)
|
|
|
|
try:
|
|
|
|
geoadmin = admin.site._registry[City]
|
|
|
|
params = geoadmin.get_map_widget(City._meta.get_field('point')).params
|
|
|
|
result = geoadmin.get_map_widget(City._meta.get_field('point'))(
|
|
|
|
).render('point', Point(-79.460734, 40.18476), params)
|
|
|
|
|
|
|
|
self.assertNotIn(delete_all_btn, result)
|
|
|
|
finally:
|
|
|
|
admin.site.unregister(City)
|
|
|
|
admin.site.register(City, original_geoadmin.__class__)
|
|
|
|
|
2012-05-25 21:00:44 +02:00
|
|
|
def test_olmap_WMS_rendering(self):
|
2013-05-15 16:45:07 +02:00
|
|
|
geoadmin = admin.GeoModelAdmin(City, admin.site)
|
2012-05-25 21:00:44 +02:00
|
|
|
result = geoadmin.get_map_widget(City._meta.get_field('point'))(
|
2013-10-18 10:02:43 +01:00
|
|
|
).render('point', Point(-79.460734, 40.18476))
|
2012-05-25 21:00:44 +02:00
|
|
|
self.assertIn(
|
2014-09-04 08:15:09 -04:00
|
|
|
"""geodjango_point.layers.base = new OpenLayers.Layer.WMS("OpenLayers WMS", """
|
|
|
|
""""http://vmap0.tiles.osgeo.org/wms/vmap0", {layers: 'basic', format: 'image/jpeg'});""",
|
2012-05-25 21:00:44 +02:00
|
|
|
result)
|
2012-06-06 10:40:11 +02:00
|
|
|
|
|
|
|
def test_olwidget_has_changed(self):
|
2013-07-22 09:55:45 +02:00
|
|
|
"""
|
|
|
|
Check that changes are accurately noticed by OpenLayersWidget.
|
|
|
|
"""
|
2012-06-06 10:40:11 +02:00
|
|
|
geoadmin = admin.site._registry[City]
|
|
|
|
form = geoadmin.get_changelist_form(None)()
|
2014-08-06 22:26:23 -04:30
|
|
|
has_changed = form.fields['point'].has_changed
|
2012-06-06 10:40:11 +02:00
|
|
|
|
|
|
|
initial = Point(13.4197458572965953, 52.5194108501149799, srid=4326)
|
|
|
|
data_same = "SRID=3857;POINT(1493879.2754093995 6894592.019687599)"
|
|
|
|
data_almost_same = "SRID=3857;POINT(1493879.2754093990 6894592.019687590)"
|
|
|
|
data_changed = "SRID=3857;POINT(1493884.0527237 6894593.8111804)"
|
|
|
|
|
|
|
|
self.assertTrue(has_changed(None, data_changed))
|
|
|
|
self.assertTrue(has_changed(initial, ""))
|
|
|
|
self.assertFalse(has_changed(None, ""))
|
|
|
|
self.assertFalse(has_changed(initial, data_same))
|
|
|
|
self.assertFalse(has_changed(initial, data_almost_same))
|
|
|
|
self.assertTrue(has_changed(initial, data_changed))
|