1
0
mirror of https://github.com/django/django.git synced 2025-10-25 14:46:09 +00:00

[1.7.x] Fixed #23303 -- Added BEGIN and COMMIT statements to the output of sqlmigrate.

Backport of 5853c87a45 from master.

Conflicts:
	django/core/management/commands/sqlmigrate.py
	tests/user_commands/tests.py
This commit is contained in:
Baptiste Mispelon
2014-08-16 17:21:14 +02:00
parent 126606c5b8
commit 3a80189479
7 changed files with 37 additions and 2 deletions

View File

@@ -19,6 +19,14 @@ class Command(BaseCommand):
) )
help = "Prints the SQL statements for the named migration." help = "Prints the SQL statements for the named migration."
output_transaction = True
def execute(self, *args, **options):
# sqlmigrate doesn't support coloring its output but we need to force
# no_color=True so that the BEGIN/COMMIT statements added by
# output_transaction don't get colored either.
options['no_color'] = True
return super(Command, self).execute(*args, **options)
def handle(self, *args, **options): def handle(self, *args, **options):
@@ -50,5 +58,4 @@ class Command(BaseCommand):
# for it # for it
plan = [(executor.loader.graph.nodes[targets[0]], options.get("backwards", False))] plan = [(executor.loader.graph.nodes[targets[0]], options.get("backwards", False))]
sql_statements = executor.collect_sql(plan) sql_statements = executor.collect_sql(plan)
for statement in sql_statements: return '\n'.join(sql_statements)
self.stdout.write(statement)

View File

@@ -480,6 +480,7 @@ readability):
.. code-block:: sql .. code-block:: sql
BEGIN;
CREATE TABLE polls_question ( CREATE TABLE polls_question (
"id" serial NOT NULL PRIMARY KEY, "id" serial NOT NULL PRIMARY KEY,
"question_text" varchar(200) NOT NULL, "question_text" varchar(200) NOT NULL,
@@ -500,6 +501,7 @@ readability):
FOREIGN KEY ("question_id") FOREIGN KEY ("question_id")
REFERENCES "polls_question" ("id") REFERENCES "polls_question" ("id")
DEFERRABLE INITIALLY DEFERRED; DEFERRABLE INITIALLY DEFERRED;
COMMIT;
Note the following: Note the following:

View File

@@ -285,6 +285,7 @@ This command should produce the following output:
.. code-block:: sql .. code-block:: sql
BEGIN;
CREATE TABLE "world_worldborder" ( CREATE TABLE "world_worldborder" (
"id" serial NOT NULL PRIMARY KEY, "id" serial NOT NULL PRIMARY KEY,
"name" varchar(50) NOT NULL, "name" varchar(50) NOT NULL,
@@ -302,6 +303,7 @@ This command should produce the following output:
) )
; ;
CREATE INDEX "world_worldborder_mpoly_id" ON "world_worldborder" USING GIST ( "mpoly" ); CREATE INDEX "world_worldborder_mpoly_id" ON "world_worldborder" USING GIST ( "mpoly" );
COMMIT;
.. note:: .. note::

View File

@@ -1127,6 +1127,8 @@ Prints the SQL for the named migration. This requires an active database
connection, which it will use to resolve constraint names; this means you must connection, which it will use to resolve constraint names; this means you must
generate the SQL against a copy of the database you wish to later apply it on. generate the SQL against a copy of the database you wish to later apply it on.
Note that ``sqlmigrate`` doesn't colorize its output.
The :djadminopt:`--database` option can be used to specify the database for The :djadminopt:`--database` option can be used to specify the database for
which to generate the SQL. which to generate the SQL.

View File

@@ -93,6 +93,13 @@ class MigrateTests(MigrationTestBase):
""" """
Makes sure that sqlmigrate does something. Makes sure that sqlmigrate does something.
""" """
# Make sure the output is wrapped in a transaction
stdout = six.StringIO()
call_command("sqlmigrate", "migrations", "0001", stdout=stdout)
output = stdout.getvalue().lower()
self.assertIn("begin;", output)
self.assertIn("commit;", output)
# Test forwards. All the databases agree on CREATE TABLE, at least. # Test forwards. All the databases agree on CREATE TABLE, at least.
stdout = six.StringIO() stdout = six.StringIO()
call_command("sqlmigrate", "migrations", "0001", stdout=stdout) call_command("sqlmigrate", "migrations", "0001", stdout=stdout)

View File

@@ -0,0 +1,10 @@
from django.core.management.base import BaseCommand
class Command(BaseCommand):
help = "Say hello."
args = ''
output_transaction = True
def handle(self, *args, **options):
return 'Hello!'

View File

@@ -74,6 +74,11 @@ class CommandTests(SimpleTestCase):
if current_path is not None: if current_path is not None:
os.environ['PATH'] = current_path os.environ['PATH'] = current_path
def test_output_transaction(self):
out = StringIO()
management.call_command('transaction', stdout=out, no_color=True)
self.assertEqual(out.getvalue(), 'BEGIN;\nHello!\n\nCOMMIT;\n')
class UtilsTests(SimpleTestCase): class UtilsTests(SimpleTestCase):