Django тестирование данных загрузки с использованием сырых SQL - PullRequest
2 голосов
/ 08 февраля 2011

У меня есть проект django, использующий несколько баз данных. Я использую Джанго-нос в качестве тест-бегуна. Тестовые данные загружаются в базу данных по умолчанию с использованием приборов. У меня есть вторая база данных, не управляемая моделями django, где я хочу создать структуру и загрузить некоторые данные перед тестированием, используя raw sql.

Есть ли способ сделать это каким-то чистым способом?

Спасибо.

1 Ответ

2 голосов
/ 11 августа 2011

Ht Stathis,

Вот мой сценарий и как я его решил - YMMV ..

1) Я создаю testrunner и перезаписываю метод setup_databases. Мне нужно было сделать это, потому что я хотел внешне создать эту базу данных. У нас были пользовательские таблицы и функции. Я буквально использовал один и тот же код с одним небольшим отклонением

class IManageTestRunner(DjangoTestSuiteRunner):
    """This is a 3 line addition to the original method"""

    def setup_databases(self, **kwargs):
        from django.db import connections, DEFAULT_DB_ALIAS

        ### Skipped for brevity ###

        for signature, (db_name, aliases) in dependency_ordered(test_databases.items(), dependencies):
            # Actually create the database for the first connection
            connection = connections[aliases[0]]
            old_names.append((connection, db_name, True))
            test_db_name = connection.creation.create_test_db(self.verbosity, autoclobber=not self.interactive)

            # Our little hack...
            if db_name == "bugs":
                create_IManage_instance(django_created_sql = True, mysql_db = "test_bugs",
                                    arg = value, arg2 = value )
            # End of our little hack..

            for alias in aliases[1:]:
                connection = connections[alias]

                ### Skipped for brevity ###

2) Добавьте это к вашим settings.py TEST_RUNNER = 'IManageTestRunner'

3) Как только это было создано, я знал, что мой тестовый БД был создан. Затем я бы создал тесты, которые заполнились бы извне, и проверил бы результаты по нему.

def test_add_property_value(self):
    """Test set / get a value"""
    # This will do some external process which occcurs to the db.
    pm = Pm(mysql_db='test_bugs', p4_port = settings.ICMSERVER_TEST_PORT)
    pmsite, pmproject, pmvariant, pmlibtype, pmlibrary, pmrelease = pm.add_release_tree()
    prop_type, pmvalue = ("string", "Funny Business")
    pmproperty = "%s_%s_basic" % (pmproject.name, prop_type)
    pm.add_property_definition(pmproperty, prop_type=prop_type)
    pm.add_propval(pmproperty, value=pmvalue, project=pmproject.name)

    # Now use Django to pull the value back out..
    project = Project.objects.get(name=pmproject.name)
    property = project.get_property(pmproperty)
    self.assertEqual(pmvalue, property.value)

Надеюсь, что это помогло мне немного разобраться. У меня все еще есть одна проблема (делает повторные вставки / запросы ..)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...