mirror of
				https://github.com/django/django.git
				synced 2025-10-22 05:09:39 +00:00 
			
		
		
		
	git-svn-id: http://code.djangoproject.com/svn/django/trunk@15055 bcc190cf-cafb-0310-a4f2-bffc1f526a37
		
			
				
	
	
		
			224 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			224 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| ======================
 | |
| Testing GeoDjango Apps
 | |
| ======================
 | |
| 
 | |
| .. versionchanged:: 1.2
 | |
| 
 | |
| In Django 1.2, the addition of :ref:`spatial-backends` simplified the
 | |
| process of testing GeoDjango applications -- the process is now the
 | |
| same as :doc:`/topics/testing`.
 | |
| 
 | |
| Included in this documentation are some additional notes and settings
 | |
| for :ref:`testing-postgis` and :ref:`testing-spatialite` users.
 | |
| 
 | |
| .. _testing-postgis:
 | |
| 
 | |
| PostGIS
 | |
| =======
 | |
| 
 | |
| Settings
 | |
| --------
 | |
| 
 | |
| .. note::
 | |
| 
 | |
|     The settings below have sensible defaults, and shouldn't require manual setting.
 | |
| 
 | |
| .. setting:: POSTGIS_TEMPLATE
 | |
| 
 | |
| ``POSTGIS_TEMPLATE``
 | |
| ^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| .. versionchanged:: 1.2
 | |
| 
 | |
| This setting may be used to customize the name of the PostGIS template
 | |
| database to use.  In Django versions 1.2 and above, it automatically
 | |
| defaults to ``'template_postgis'`` (the same name used in the
 | |
| :ref:`installation documentation <spatialdb_template>`).
 | |
| 
 | |
| .. setting:: POSTGIS_VERSION
 | |
| 
 | |
| ``POSTGIS_VERSION``
 | |
| ^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| When GeoDjango's spatial backend initializes on PostGIS, it has to perform
 | |
| a SQL query to determine the version in order to figure out what
 | |
| features are available.  Advanced users wishing to prevent this additional
 | |
| query may set the version manually using a 3-tuple of integers specifying
 | |
| the major, minor, and subminor version numbers for PostGIS.  For example,
 | |
| to configure for PostGIS 1.5.2 you would use::
 | |
| 
 | |
|     POSTGIS_VERSION = (1, 5, 2)
 | |
| 
 | |
| Obtaining Sufficient Privileges
 | |
| -------------------------------
 | |
| 
 | |
| Depending on your configuration, this section describes several methods to
 | |
| configure a database user with sufficient privileges to run tests for
 | |
| GeoDjango applications on PostgreSQL.  If your
 | |
| :ref:`spatial database template <spatialdb_template>`
 | |
| was created like in the instructions, then your testing database user
 | |
| only needs to have the ability to create databases.  In other configurations,
 | |
| you may be required to use a database superuser.
 | |
| 
 | |
| Create Database User
 | |
| ^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| To make database user with the ability to create databases, use the
 | |
| following command::
 | |
| 
 | |
|     $ createuser --createdb -R -S <user_name>
 | |
| 
 | |
| The ``-R -S`` flags indicate that we do not want the user to have the ability
 | |
| to create additional users (roles) or to be a superuser, respectively.
 | |
| 
 | |
| Alternatively, you may alter an existing user's role from the SQL shell
 | |
| (assuming this is done from an existing superuser account)::
 | |
| 
 | |
|     postgres# ALTER ROLE <user_name> CREATEDB NOSUPERUSER NOCREATEROLE;
 | |
| 
 | |
| Create Database Superuser
 | |
| ^^^^^^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| This may be done at the time the user is created, for example::
 | |
| 
 | |
|     $ createuser --superuser <user_name>
 | |
| 
 | |
| Or you may alter the user's role from the SQL shell (assuming this
 | |
| is done from an existing superuser account)::
 | |
| 
 | |
|     postgres# ALTER ROLE <user_name> SUPERUSER;
 | |
| 
 | |
| 
 | |
| Create Local PostgreSQL Database
 | |
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| 1. Initialize database: ``initdb -D /path/to/user/db``
 | |
| 
 | |
| 2. If there's already a Postgres instance on the machine, it will need
 | |
|    to use a different TCP port than 5432. Edit ``postgresql.conf`` (in
 | |
|    ``/path/to/user/db``) to change the database port (e.g. ``port = 5433``).
 | |
| 
 | |
| 3. Start this database ``pg_ctl -D /path/to/user/db start``
 | |
| 
 | |
| Windows
 | |
| -------
 | |
| 
 | |
| On Windows platforms the pgAdmin III utility may also be used as
 | |
| a simple way to add superuser privileges to your database user.
 | |
| 
 | |
| By default, the PostGIS installer on Windows includes a template
 | |
| spatial database entitled ``template_postgis``.
 | |
| 
 | |
| .. _testing-spatialite:
 | |
| 
 | |
| SpatiaLite
 | |
| ==========
 | |
| 
 | |
| You will need to download the `initialization SQL`__ script for SpatiaLite::
 | |
| 
 | |
|     $ wget http://www.gaia-gis.it/spatialite/init_spatialite-2.3.zip
 | |
|     $ unzip init_spatialite-2.3.zip
 | |
| 
 | |
| If ``init_spatialite-2.3.sql`` is in the same path as your project's ``manage.py``,
 | |
| then all you have to do is::
 | |
| 
 | |
|     $ python manage.py test
 | |
| 
 | |
| Settings
 | |
| --------
 | |
| 
 | |
| .. setting:: SPATIALITE_SQL
 | |
| 
 | |
| ``SPATIALITE_SQL``
 | |
| ^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| By default, the GeoDjango test runner looks for the SpatiaLite SQL in the
 | |
| same directory where it was invoked (by default the same directory where
 | |
| ``manage.py`` is located).  If you want to use a different location, then
 | |
| you may add the following to your settings::
 | |
| 
 | |
|     SPATIALITE_SQL='/path/to/init_spatialite-2.3.sql'
 | |
| 
 | |
| __ http://www.gaia-gis.it/spatialite/init_spatialite-2.3.zip
 | |
| 
 | |
| 
 | |
| .. _geodjango-tests:
 | |
| 
 | |
| GeoDjango Tests
 | |
| ===============
 | |
| 
 | |
| .. versionchanged:: 1.3
 | |
| 
 | |
| GeoDjango's test suite may be run in one of two ways, either by itself or
 | |
| with the rest of :ref:`Django's unit tests <unit-tests>`.
 | |
| 
 | |
| Run only GeoDjango tests
 | |
| ------------------------
 | |
| 
 | |
| To run *only* the tests for GeoDjango, the :setting:`TEST_RUNNER`
 | |
| setting must be changed to use the
 | |
| :class:`~django.contrib.gis.tests.GeoDjangoTestSuiteRunner`::
 | |
| 
 | |
|     TEST_RUNNER = 'django.contrib.gis.tests.GeoDjangoTestSuiteRunner'
 | |
| 
 | |
| Example
 | |
| ^^^^^^^
 | |
| 
 | |
| First, you'll need a bare-bones settings file, like below, that is
 | |
| customized with your spatial database name and user::
 | |
| 
 | |
|     TEST_RUNNER = 'django.contrib.gis.tests.GeoDjangoTestSuiteRunner'
 | |
| 
 | |
|     DATABASES = {
 | |
|         'default': {
 | |
|             'ENGINE': 'django.contrib.gis.db.backends.postgis',
 | |
|             'NAME': 'a_spatial_database',
 | |
|             'USER': 'db_user'
 | |
|         }
 | |
|     }
 | |
| 
 | |
| Assuming the above is in a file called ``postgis.py`` that is in the
 | |
| the same directory as ``manage.py`` of your Django project, then
 | |
| you may run the tests with the following command::
 | |
| 
 | |
|     $ python manage.py test --settings=postgis
 | |
| 
 | |
| Run with ``runtests.py``
 | |
| ------------------------
 | |
| 
 | |
| To have the GeoDjango tests executed when
 | |
| :ref:`running the Django test suite <running-unit-tests>` with ``runtests.py``
 | |
| all of the databases in the settings file must be using one of the
 | |
| :ref:`spatial database backends <spatial-backends>`.
 | |
| 
 | |
| .. warning::
 | |
| 
 | |
|     Do not change the :setting:`TEST_RUNNER` setting
 | |
|     when running the GeoDjango tests with ``runtests.py``.
 | |
| 
 | |
| Example
 | |
| ^^^^^^^
 | |
| 
 | |
| The following is an example bare-bones settings file with spatial backends
 | |
| that can be used to run the entire Django test suite, including those
 | |
| in :mod:`django.contrib.gis`::
 | |
| 
 | |
|     DATABASES = {
 | |
|         'default': {
 | |
|             'ENGINE': 'django.contrib.gis.db.backends.postgis',
 | |
|             'NAME': 'geodjango',
 | |
|             'USER': 'geodjango',
 | |
|         },
 | |
|        'other': {
 | |
|             'ENGINE': 'django.contrib.gis.db.backends.postgis',
 | |
|             'NAME': 'other',
 | |
|             'USER': 'geodjango',
 | |
|        }
 | |
|     }
 | |
| 
 | |
| Assuming the settings above were in a ``postgis.py`` file in the same
 | |
| directory as ``runtests.py``, then all Django and GeoDjango tests would
 | |
| be performed when executing the command::
 | |
| 
 | |
|     $ ./runtests.py --settings=postgis
 |