0

我想要一个在运行应用程序时表现不同的 settings.py 文件

./manage.py runserver

并且在测试时

./manage.py test myapp

因此,我可以将测试数据库更改为 sqlite,例如:

if IS_TESTING:
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.sqlite3', 
            'NAME': 'test_db',                      
        }
    }
else:
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.postgresql_psycopg2', 
            'NAME': DATABASE_NAME,                      
            'USER': DATABASE_USER,                      
            'PASSWORD': DATABASE_PASS,                  
            'HOST': 'localhost',                      
            'PORT': '5432',                      
        }
    }

我可以通过像这样更改 manage.py 脚本来获得这种行为:

if __name__ == "__main__":
    os.environ.setdefault('IS_TESTING', 'false')
    print 'off'
    if sys.argv[1] == 'test':
        print 'on'
        os.environ['IS_TESTING'] = 'true'
    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "frespo.settings")

    from django.core.management import execute_from_command_line

    execute_from_command_line(sys.argv)

但我认为这仍然不够好,因为当我在 IDE (PyCharm) 中运行测试时,它不会使用我的自定义 manage.py 文件。在 Django 中必须有一个变量。你知道在哪里吗?

4

2 回答 2

5

如果您仅出于 Django 单元测试的目的需要此条件,则文件中的以下行settings.py应该可以工作:

if 'test' in sys.argv:
    DATABASES['default']['ENGINE'] = 'django.db.backends.sqlite3'
    SOUTH_TESTS_MIGRATE = False # if you're using south

这假定DATABASES始终声明其他标准设置。上面的行只是sqlite在单元测试运行的情况下将数据库设置为。

于 2012-10-07T18:58:07.143 回答
0

Afaik Django 没有这样的变量。假设您可以编辑 PyCharm 运行的确切命令,您只需在此处添加测试参数,然后在 settings.py 文件中查找它。

if "test-argument" in sys.argv:
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.sqlite3', 
            'NAME': 'test_db',                      
        }
    }
else:
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.postgresql_psycopg2', 
            'NAME': DATABASE_NAME,                      
            'USER': DATABASE_USER,                      
            'PASSWORD': DATABASE_PASS,                  
            'HOST': 'localhost',                      
            'PORT': '5432',                      
        }
    }
于 2012-10-07T18:59:00.270 回答