1
0
mirror of https://github.com/django/django.git synced 2025-01-05 07:55:47 +00:00

Fixed #25658 -- Allowed inspectdb to inspect a specific set of tables.

This commit is contained in:
José Tomás Tocino 2015-11-02 00:53:43 +01:00 committed by Tim Graham
parent f15f4b8bb6
commit 39a16dd2e0
5 changed files with 28 additions and 3 deletions

View File

@ -373,6 +373,7 @@ answer newbie questions, and generally made Django that much better:
Jordan Dimov <s3x3y1@gmail.com> Jordan Dimov <s3x3y1@gmail.com>
Jorge Bastida <me@jorgebastida.com> Jorge Bastida <me@jorgebastida.com>
Jorge Gajon <gajon@gajon.org> Jorge Gajon <gajon@gajon.org>
José Tomás Tocino García <josetomas.tocino@gmail.com>
Joseph Kocherhans <joseph@jkocherhans.com> Joseph Kocherhans <joseph@jkocherhans.com>
Josh Smeaton <josh.smeaton@gmail.com> Josh Smeaton <josh.smeaton@gmail.com>
Joshua Ginsberg <jag@flowtheory.net> Joshua Ginsberg <jag@flowtheory.net>

View File

@ -17,6 +17,8 @@ class Command(BaseCommand):
db_module = 'django.db' db_module = 'django.db'
def add_arguments(self, parser): def add_arguments(self, parser):
parser.add_argument('table', action='store', nargs='*', type=str,
help='Selects what tables or views should be introspected.')
parser.add_argument('--database', action='store', dest='database', parser.add_argument('--database', action='store', dest='database',
default=DEFAULT_DB_ALIAS, help='Nominates a database to ' default=DEFAULT_DB_ALIAS, help='Nominates a database to '
'introspect. Defaults to using the "default" database.') 'introspect. Defaults to using the "default" database.')
@ -54,7 +56,9 @@ class Command(BaseCommand):
yield '' yield ''
yield 'from %s import models' % self.db_module yield 'from %s import models' % self.db_module
known_models = [] known_models = []
for table_name in connection.introspection.table_names(cursor): tables_to_introspect = options['table'] or connection.introspection.table_names(cursor)
for table_name in tables_to_introspect:
if table_name_filter is not None and callable(table_name_filter): if table_name_filter is not None and callable(table_name_filter):
if not table_name_filter(table_name): if not table_name_filter(table_name):
continue continue

View File

@ -354,11 +354,12 @@ Specifies the database to flush. Defaults to ``default``.
``inspectdb`` ``inspectdb``
------------- -------------
.. django-admin:: inspectdb .. django-admin:: inspectdb [table [table ...]]
Introspects the database tables in the database pointed-to by the Introspects the database tables in the database pointed-to by the
:setting:`NAME` setting and outputs a Django model module (a ``models.py`` :setting:`NAME` setting and outputs a Django model module (a ``models.py``
file) to standard output. file) to standard output. You may choose what tables to inspect by passing
their names as arguments.
Use this if you have a legacy database with which you'd like to use Django. Use this if you have a legacy database with which you'd like to use Django.
The script will inspect the database and create a model for each table within The script will inspect the database and create a model for each table within
@ -406,6 +407,11 @@ table's lifecycle, you'll need to change the
:attr:`~django.db.models.Options.managed` option to ``True`` (or simply remove :attr:`~django.db.models.Options.managed` option to ``True`` (or simply remove
it because ``True`` is its default value). it because ``True`` is its default value).
.. versionadded:: 1.10
Support for the ``table`` argument(s) to choose what tables should be
inspected was added.
.. django-admin-option:: --database DATABASE .. django-admin-option:: --database DATABASE
Specifies the database to introspect. Defaults to ``default``. Specifies the database to introspect. Defaults to ``default``.

View File

@ -292,6 +292,9 @@ Management Commands
* The :djadmin:`shell` command supports tab completion on systems using * The :djadmin:`shell` command supports tab completion on systems using
``libedit``, e.g. Mac OSX. ``libedit``, e.g. Mac OSX.
* The :djadmin:`inspectdb` command lets you choose what tables should be
inspected by specifying their names as arguments.
Migrations Migrations
~~~~~~~~~~ ~~~~~~~~~~

View File

@ -28,6 +28,17 @@ class InspectDBTestCase(TestCase):
# inspected # inspected
self.assertNotIn("class DjangoContentType(models.Model):", out.getvalue(), msg=error_message) self.assertNotIn("class DjangoContentType(models.Model):", out.getvalue(), msg=error_message)
def test_table_option(self):
"""
inspectdb can inspect a subset of tables by passing the table names as
arguments.
"""
out = StringIO()
call_command('inspectdb', 'inspectdb_people', stdout=out)
output = out.getvalue()
self.assertIn('class InspectdbPeople(models.Model):', output)
self.assertNotIn("InspectdbPeopledata", output)
def make_field_type_asserter(self): def make_field_type_asserter(self):
"""Call inspectdb and return a function to validate a field type in its output""" """Call inspectdb and return a function to validate a field type in its output"""
out = StringIO() out = StringIO()