Django:为啥我在运行 LiveServerTestCase 测试时无法获得回溯(以防出错)?

Posted

技术标签:

【中文标题】Django:为啥我在运行 LiveServerTestCase 测试时无法获得回溯(以防出错)?【英文标题】:Django: why i can't get the tracebacks (in case of error) when i run LiveServerTestCase tests?Django:为什么我在运行 LiveServerTestCase 测试时无法获得回溯(以防出错)? 【发布时间】:2013-01-12 01:41:09 【问题描述】:

我正在用 Selenium 编写一些测试。

当我运行我的 selenium 测试(LiveServerTestCase 类型)并且我的代码中有一些错误(不是在测试中,我的意思是在执行的代码中,比如我使用 selenium 访问的主页视图)我得到了 500 模板(通常当我有 DEBUG = False 时我会得到)即使我有:

DEBUG = True 
INTERNAL_IPS = ('127.0.0.1',)

我被困住了,我不明白为什么我的测试失败了(因为在公共 500 中我没有显示异常)。

为什么会这样?我在哪里可以解决?

当我运行 runserver 时,它运行良好(我得到了回溯)。

【问题讨论】:

【参考方案1】:

来自 django 文档https://docs.djangoproject.com/en/1.4/topics/testing/#other-test-conditions

目前似乎无法覆盖它,即使使用https://docs.djangoproject.com/en/1.4/topics/testing/#django.test.utils.override_settings

在返回 500 响应时查看调试信息的唯一方法是记录它。

编辑:我找到了一种在我的硒测试中设置DEBUG = True 的方法。 在我的子类中,我重写了构造函数并更改了设置。

from django.conf import settings

class SeleniumLiveServerTestCase(LiveServerTestCase):

    def __init__(self, *args, **kwargs):
        super(SeleniumLiveServerTestCase, self).__init__(*args, **kwargs)
        if settings.DEBUG == False:
            settings.DEBUG = True

虽然很丑,但是很管用!

【讨论】:

【参考方案2】:

我遇到了同样的问题,现在可以覆盖设置。

根据您的示例,您将导入 override_settings 并将装饰器放在类上方:

from django.test import override_settings

@override_settings(DEBUG=True)
class SeleniumLiveServerTestCase(LiveServerTestCase):

    ...

详情在django docs

【讨论】:

【参考方案3】:

我自己对 Selenium 测试套件不是很熟悉,但我知道如果您正在部署应用程序并且您的 IP 地址未在“INTERNAL_IPS”元组中注册,即使 DEBUG 也可能看不到回溯设置为真。当您使用 Django 的 runserver 时,它会自动将您的本地计算机添加到 INTERNAL_IPS 设置中,但通常这是一个空元组。我敢打赌,Selenium 并没有为您做到这一点,这可能就是您看不到回溯的原因。如果您还没有添加,我会尝试添加。

这样的东西应该可以正常工作:

INTERNAL_IPS = ('127.0.0.1',)

Django Settings (INTERNAL_IPS)

【讨论】:

遗憾的是,我的 settings.py 中已经有了这个:|我会尝试调试它,看看它在测试运行时是否设置正确 我已经更新了问题,不涉及 django social auth,即使我在到达的第一个视图中添加了缩进错误,我也会得到 500

以上是关于Django:为啥我在运行 LiveServerTestCase 测试时无法获得回溯(以防出错)?的主要内容,如果未能解决你的问题,请参考以下文章

为啥我在 Django 中使用此调用从 Paypal 收到“内部错误”?

为啥无法访问 Django 基本 URL?

为啥这个 Django 日志记录不起作用?

为啥部署 django docker 容器后,邮件发送失败?

为啥我在 Django 中有这个错误?

为啥我在运行时出现整数精度错误:heroku run python manage.py migrate