當前位置: 首頁>>代碼示例>>Python>>正文


Python migrations.Migration方法代碼示例

本文整理匯總了Python中django.db.migrations.Migration方法的典型用法代碼示例。如果您正苦於以下問題:Python migrations.Migration方法的具體用法?Python migrations.Migration怎麽用?Python migrations.Migration使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在django.db.migrations的用法示例。


在下文中一共展示了migrations.Migration方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: get_fake_model

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def get_fake_model(fields=None, model_base=LocalizedModel, meta_options={}):
    """Creates a fake model to use during unit tests."""

    model = define_fake_model(fields, model_base, meta_options)

    class TestProject:
        def clone(self, *_args, **_kwargs):
            return self

        @property
        def apps(self):
            return self

    class TestMigration(migrations.Migration):
        operations = [HStoreExtension()]

    with connection.schema_editor() as schema_editor:
        migration_executor = MigrationExecutor(schema_editor.connection)
        migration_executor.apply_migration(
            TestProject(), TestMigration("eh", "postgres_extra")
        )

        schema_editor.create_model(model)

    return model 
開發者ID:SectorLabs,項目名稱:django-localized-fields,代碼行數:27,代碼來源:fake_model.py

示例2: test_custom_operation

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def test_custom_operation(self):
        migration = type(str("Migration"), (migrations.Migration,), {
            "operations": [
                custom_migration_operations.operations.TestOperation(),
                custom_migration_operations.operations.CreateModel(),
                migrations.CreateModel("MyModel", (), {}, (models.Model,)),
                custom_migration_operations.more_operations.TestOperation()
            ],
            "dependencies": []
        })
        writer = MigrationWriter(migration)
        output = writer.as_string()
        result = self.safe_exec(output)
        self.assertIn("custom_migration_operations", result)
        self.assertNotEqual(
            result['custom_migration_operations'].operations.TestOperation,
            result['custom_migration_operations'].more_operations.TestOperation
        ) 
開發者ID:denisenkom,項目名稱:django-sqlserver,代碼行數:20,代碼來源:test_writer.py

示例3: test_sorted_imports

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def test_sorted_imports(self):
        """
        #24155 - Tests ordering of imports.
        """
        migration = type(str("Migration"), (migrations.Migration,), {
            "operations": [
                migrations.AddField("mymodel", "myfield", models.DateTimeField(
                    default=datetime.datetime(2012, 1, 1, 1, 1, tzinfo=utc),
                )),
            ]
        })
        writer = MigrationWriter(migration)
        output = writer.as_string()
        self.assertIn(
            "import datetime\n"
            "from django.db import migrations, models\n"
            "from django.utils.timezone import utc\n",
            output
        ) 
開發者ID:denisenkom,項目名稱:django-sqlserver,代碼行數:21,代碼來源:test_writer.py

示例4: test_custom_operation

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def test_custom_operation(self):
        migration = type("Migration", (migrations.Migration,), {
            "operations": [
                custom_migration_operations.operations.TestOperation(),
                custom_migration_operations.operations.CreateModel(),
                migrations.CreateModel("MyModel", (), {}, (models.Model,)),
                custom_migration_operations.more_operations.TestOperation()
            ],
            "dependencies": []
        })
        writer = MigrationWriter(migration)
        output = writer.as_string()
        result = self.safe_exec(output)
        self.assertIn("custom_migration_operations", result)
        self.assertNotEqual(
            result['custom_migration_operations'].operations.TestOperation,
            result['custom_migration_operations'].more_operations.TestOperation
        ) 
開發者ID:nesdis,項目名稱:djongo,代碼行數:20,代碼來源:test_writer.py

示例5: test_sorted_imports

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def test_sorted_imports(self):
        """
        #24155 - Tests ordering of imports.
        """
        migration = type("Migration", (migrations.Migration,), {
            "operations": [
                migrations.AddField("mymodel", "myfield", models.DateTimeField(
                    default=datetime.datetime(2012, 1, 1, 1, 1, tzinfo=utc),
                )),
            ]
        })
        writer = MigrationWriter(migration)
        output = writer.as_string()
        self.assertIn(
            "import datetime\n"
            "from django.db import migrations, models\n"
            "from django.utils.timezone import utc\n",
            output
        ) 
開發者ID:nesdis,項目名稱:djongo,代碼行數:21,代碼來源:test_writer.py

示例6: test_migration_file_header_comments

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def test_migration_file_header_comments(self):
        """
        Test comments at top of file.
        """
        migration = type("Migration", (migrations.Migration,), {
            "operations": []
        })
        dt = datetime.datetime(2015, 7, 31, 4, 40, 0, 0, tzinfo=utc)
        with mock.patch('django.db.migrations.writer.now', lambda: dt):
            for include_header in (True, False):
                with self.subTest(include_header=include_header):
                    writer = MigrationWriter(migration, include_header)
                    output = writer.as_string()

                    self.assertEqual(
                        include_header,
                        output.startswith(
                            "# Generated by Django %s on 2015-07-31 04:40\n\n" % get_version()
                        )
                    )
                    if not include_header:
                        # Make sure the output starts with something that's not
                        # a comment or indentation or blank line
                        self.assertRegex(output.splitlines(keepends=True)[0], r"^[^#\s]+") 
開發者ID:nesdis,項目名稱:djongo,代碼行數:26,代碼來源:test_writer.py

示例7: get_fake_model

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def get_fake_model(fields=None, model_base=models.Model, options=None):
    fields = fields if fields else {}
    options = options if options else {}
    """Create fake model to use during unit tests."""

    model = define_fake_model(fields, model_base, options)

    class TestProject:
        def clone(self, *_args, **_kwargs):
            return self

    class TestMigration(migrations.Migration):
        operations = [HStoreExtension()]

    with connection.schema_editor() as schema_editor:
        migration_executor = MigrationExecutor(schema_editor.connection)
        migration_executor.apply_migration(
            TestProject(), TestMigration("caluma_extra", "caluma_core")
        )

        schema_editor.create_model(model)

    return model 
開發者ID:projectcaluma,項目名稱:caluma,代碼行數:25,代碼來源:fake_model.py

示例8: test_has_errors

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def test_has_errors(self):
        linter = MigrationLinter(database="mysql")
        self.assertFalse(linter.has_errors)

        m = Migration("0001_create_table", "app_add_not_null_column")
        linter.lint_migration(m)
        self.assertFalse(linter.has_errors)

        m = Migration("0002_add_new_not_null_field", "app_add_not_null_column")
        linter.lint_migration(m)
        self.assertTrue(linter.has_errors)

        m = Migration("0001_create_table", "app_add_not_null_column")
        linter.lint_migration(m)
        self.assertTrue(linter.has_errors) 
開發者ID:3YOURMIND,項目名稱:django-migration-linter,代碼行數:17,代碼來源:test_linter.py

示例9: test_exclude_migration_tests

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def test_exclude_migration_tests(self):
        m = Migration("0002_add_new_not_null_field", "app_add_not_null_column")

        linter = MigrationLinter(exclude_migration_tests=[], database="mysql")
        linter.lint_migration(m)
        self.assertTrue(linter.has_errors)

        linter = MigrationLinter(exclude_migration_tests=["NOT_NULL"], database="mysql")
        linter.lint_migration(m)
        self.assertFalse(linter.has_errors) 
開發者ID:3YOURMIND,項目名稱:django-migration-linter,代碼行數:12,代碼來源:test_linter.py

示例10: _filter_predicate

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def _filter_predicate(target: MigrationTarget, migration: Migration) -> bool:
    # when ``None`` passed as migration name then initial migration from
    # target's app will be chosen and handled properly in ``_get_index``
    # so in final all target app migrations will be excluded from plan
    index = 2 - (target[1] is None)
    return (migration.app_label, migration.name)[:index] == target[:index] 
開發者ID:wemake-services,項目名稱:django-test-migrations,代碼行數:8,代碼來源:plan.py

示例11: backwards

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def backwards(apps, schema_editor):
    """
    Migration nullified after squash of papers
    """
    pass 
開發者ID:dissemin,項目名稱:dissemin,代碼行數:7,代碼來源:0002_update_aliases.py

示例12: fix_duplicate_attachments

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def fix_duplicate_attachments(apps: StateApps, schema_editor: DatabaseSchemaEditor) -> None:
    """Migration 0041 had a bug, where if multiple messages referenced the
    same attachment, rather than creating a single attachment object
    for all of them, we would incorrectly create one for each message.
    This results in exceptions looking up the Attachment object
    corresponding to a file that was used in multiple messages that
    predate migration 0041.

    This migration fixes this by removing the duplicates, moving their
    messages onto a single canonical Attachment object (per path_id).
    """
    Attachment = apps.get_model('zerver', 'Attachment')
    # Loop through all groups of Attachment objects with the same `path_id`
    for group in Attachment.objects.values('path_id').annotate(Count('id')).order_by().filter(id__count__gt=1):
        # Sort by the minimum message ID, to find the first attachment
        attachments = sorted(list(Attachment.objects.filter(path_id=group['path_id']).order_by("id")),
                             key = lambda x: min(x.messages.all().values_list('id')[0]))
        surviving = attachments[0]
        to_cleanup = attachments[1:]
        for a in to_cleanup:
            # For each duplicate attachment, we transfer its messages
            # to the canonical attachment object for that path, and
            # then delete the original attachment.
            for msg in a.messages.all():
                surviving.messages.add(msg)
            surviving.is_realm_public = surviving.is_realm_public or a.is_realm_public
            surviving.save()
            a.delete() 
開發者ID:zulip,項目名稱:zulip,代碼行數:30,代碼來源:0074_fix_duplicate_attachments.py

示例13: migrate_daily_recurrences

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def migrate_daily_recurrences(apps, schema_editor):
    """
    Migration to convert weekly recurrences into new complex recurrences
    """
    Schedule = apps.get_model("schedules", "Schedule")
    for schedule in Schedule.objects.all():
        schedule.recurrences = recurrence.Recurrence(rrules=[recurrence.Rule(recurrence.WEEKLY, byday=(int(schedule.day), ))])
        schedule.save() 
開發者ID:iago1460,項目名稱:django-radio,代碼行數:10,代碼來源:0004__v3_0__adding_rrules.py

示例14: rollback_base_playbook_name

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def rollback_base_playbook_name(apps, schema_editor):
    """
    On rollback, warn that all custom playbook names will be lost.
    The defaults, based on the openedx_release, can be recalculated using the
    function above when the migration is performed.
    """
    print('\nReverting this migration causes data loss...')
    print('All customized playbook_names set will be lost!')


# Migration ################################################################### 
開發者ID:open-craft,項目名稱:opencraft,代碼行數:13,代碼來源:0114_introduce_base_playbook_name.py

示例15: populate_data_type_tags

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import Migration [as 別名]
def populate_data_type_tags(apps, schema_editor):
    # Go through all of the Ingest models and convert the data_type string into an array of tags
    
    update = 'UPDATE ingest SET data_type_tags = string_to_array(data_type,\',\') WHERE data_type <> \'\''
    with connection.cursor() as cursor:
        cursor.execute(update)
        count = cursor.rowcount
        if count:
            print('%d entries updated with data type tags' % count)

    print ('Migration finished.') 
開發者ID:ngageoint,項目名稱:scale,代碼行數:13,代碼來源:0017_populate_data_type_tags.py


注:本文中的django.db.migrations.Migration方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。