2007-08-17 07:05:00 +08:00
|
|
|
from django.core.management.base import BaseCommand
|
|
|
|
|
2007-09-10 05:57:59 +08:00
|
|
|
from optparse import make_option
|
|
|
|
|
2013-11-03 04:12:09 +08:00
|
|
|
|
2007-08-17 07:05:00 +08:00
|
|
|
class Command(BaseCommand):
|
2007-09-10 05:57:59 +08:00
|
|
|
option_list = BaseCommand.option_list + (
|
2010-06-21 20:09:25 +08:00
|
|
|
make_option('--noinput', action='store_false', dest='interactive', default=True,
|
|
|
|
help='Tells Django to NOT prompt the user for input of any kind.'),
|
2008-10-02 20:57:13 +08:00
|
|
|
make_option('--addrport', action='store', dest='addrport',
|
2007-09-15 03:17:15 +08:00
|
|
|
type='string', default='',
|
|
|
|
help='port number or ipaddr:port to run the server on'),
|
2010-11-26 21:33:53 +08:00
|
|
|
make_option('--ipv6', '-6', action='store_true', dest='use_ipv6', default=False,
|
|
|
|
help='Tells Django to use a IPv6 address.'),
|
2007-09-10 05:57:59 +08:00
|
|
|
)
|
2007-08-17 07:05:00 +08:00
|
|
|
help = 'Runs a development server with data from the given fixture(s).'
|
|
|
|
args = '[fixture ...]'
|
|
|
|
|
|
|
|
requires_model_validation = False
|
|
|
|
|
|
|
|
def handle(self, *fixture_labels, **options):
|
|
|
|
from django.core.management import call_command
|
2008-08-11 20:11:25 +08:00
|
|
|
from django.db import connection
|
2007-08-17 07:05:00 +08:00
|
|
|
|
2011-10-23 11:43:43 +08:00
|
|
|
verbosity = int(options.get('verbosity'))
|
|
|
|
interactive = options.get('interactive')
|
2007-09-15 03:17:15 +08:00
|
|
|
addrport = options.get('addrport')
|
2007-08-17 07:05:00 +08:00
|
|
|
|
|
|
|
# Create a test database.
|
2010-06-21 20:09:25 +08:00
|
|
|
db_name = connection.creation.create_test_db(verbosity=verbosity, autoclobber=not interactive)
|
2007-08-17 07:05:00 +08:00
|
|
|
|
|
|
|
# Import the fixture data into the test database.
|
|
|
|
call_command('loaddata', *fixture_labels, **{'verbosity': verbosity})
|
|
|
|
|
|
|
|
# Run the development server. Turn off auto-reloading because it causes
|
|
|
|
# a strange error -- it causes this handle() method to be called
|
|
|
|
# multiple times.
|
|
|
|
shutdown_message = '\nServer stopped.\nNote that the test database, %r, has not been deleted. You can explore it on your own.' % db_name
|
2012-05-15 15:18:16 +08:00
|
|
|
use_threading = connection.features.test_db_allows_multiple_connections
|
|
|
|
call_command('runserver',
|
|
|
|
addrport=addrport,
|
|
|
|
shutdown_message=shutdown_message,
|
|
|
|
use_reloader=False,
|
|
|
|
use_ipv6=options['use_ipv6'],
|
|
|
|
use_threading=use_threading
|
|
|
|
)
|