From 24d9aee1880ced5892af42f35539a5d705adf512 Mon Sep 17 00:00:00 2001 From: Baptiste Mispelon Date: Tue, 19 Aug 2014 16:56:01 +0200 Subject: [PATCH] [1.7.x] Fixed broken tests on Oracle after 5853c87a458f62ebd62d7809168355610de2570c. Oracle doesn't have a `BEGIN` statement so the test would fail. Refs #23303 Backport of 54164b814cab71a8a0503743befbdcc99ae6c7a0 from master. --- tests/migrations/test_commands.py | 8 ++++---- tests/user_commands/tests.py | 5 ++++- 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/tests/migrations/test_commands.py b/tests/migrations/test_commands.py index 8fe2a7e4a5..00b7f65ab8 100644 --- a/tests/migrations/test_commands.py +++ b/tests/migrations/test_commands.py @@ -6,7 +6,7 @@ import os import shutil from django.apps import apps -from django.db import models +from django.db import connection, models from django.core.management import call_command, CommandError from django.db.migrations import questioner from django.test import override_settings, override_system_checks @@ -96,9 +96,9 @@ class MigrateTests(MigrationTestBase): # 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) + output = stdout.getvalue() + self.assertIn(connection.ops.start_transaction_sql(), output) + self.assertIn(connection.ops.end_transaction_sql(), output) # Test forwards. All the databases agree on CREATE TABLE, at least. stdout = six.StringIO() diff --git a/tests/user_commands/tests.py b/tests/user_commands/tests.py index 1d405bec1c..ee746f7b52 100644 --- a/tests/user_commands/tests.py +++ b/tests/user_commands/tests.py @@ -1,6 +1,7 @@ import os import sys +from django.db import connection from django.core import management from django.core.management import CommandError from django.core.management.utils import find_command, popen_wrapper @@ -77,7 +78,9 @@ class CommandTests(SimpleTestCase): 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') + output = out.getvalue().strip() + self.assertTrue(output.startswith(connection.ops.start_transaction_sql())) + self.assertTrue(output.endswith(connection.ops.end_transaction_sql())) class UtilsTests(SimpleTestCase):