因此,在将预期结果与带有表单输入的实际html进行比较时,我一直在Django中返回“失败”测试,因此我打印出结果并意识到差异是由{% csrf_token %}引起的相当简单的一行,如下所示:

<input type='hidden' name='csrfmiddlewaretoken' value='hrPLKVOlhAIXmxcHI4XaFjqgEAMCTfUa' />

因此,我希望得到一个简单的答案,但我一直无法找到它:
如何渲染csrf_token的结果以用于测试?

这是测试设置和失败:
def test_home_page_returns_correct_html_with_POST(self):
        request = HttpRequest()
        request.method = 'POST'
        request.POST['item_text'] = 'A new list item'

        response = home_page(request)

        self.assertIn('A new list item', response.content.decode())

        expected_html = render_to_string(
        'home.html',
        {'new_item_text': 'A new list item'},
******this is where I'm hoping for a simple one-line mapping******

    )
    self.assertEqual(response.content.decode(), expected_html)

这是views.py的渲染:
def home_page(request):
    return render(request, 'home.html', {
        'new_item_text': request.POST.get('item_text'),
    })

这是测试失败,当我使用python manage.py test运行测试时
FAIL: test_home_page_returns_correct_html_with_POST (lists.tests.HomePageTest)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "C:\Users\Me\PycharmProjects\superlists\lists\tests.py", line 29, in test_home_page_returns_correct_html_with_POST
    self.assertEqual(response.content.decode(), expected_html)
AssertionError: '<!DO[298 chars]     <input type=\'hidden\' name=\'csrfmiddlew[179 chars]tml>' != '<!DO[298 chars]     \n    </form>\n\n    <table
 id="id_list_t[82 chars]tml>'

----------------------------------------------------------------------

最佳答案

从您提供的代码片段来看,您似乎正在研究“使用Python进行测试驱动的开发”一书中的示例,但并未使用Django 1.8。

该书的Google网上论坛讨论中的这篇帖子解决了您遇到的测试失败的问题:

https://groups.google.com/forum/#!topic/obey-the-testing-goat-book/fwY7ifEWKMU/discussion

GitHub问题(来自本书的官方存储库)描述了与您的问题相符的修复程序:

https://github.com/hjwp/book-example/issues/8

关于python - CSRF token 干扰TDD-是否存在存储csrf输出的变量?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/35582333/

10-16 03:54
查看更多