python - django.test.client 在现有 url 上出现 404 错误

标签 python django unit-testing django-unittest

我刚开始学习单元测试并坚持解决这个问题。

我得到了这样的项目结构(现在是 Django 1.6.2):

./manage.py
./myproject
./myproject/urls.py
./myproject/myapp/
./myproject/myapp/urls.py
./myproject/myapp/views.py
./tests/
./test/test_example.py

在 ./myproject/urls.py 我有:
from django.conf.urls import patterns, include, url
urlpatterns = patterns('',
    url(r'^myapp/', include('myproject.myapp.urls')),
)

在 ./myproject/myapp/urls.py 我有:
from django.conf.urls import patterns, url

urlpatterns = patterns('myproject.myapp.views',
    url(r'^example1/$', 'itemlist'),  
    url(r'^example1/(?P<item_id>\w+)/$', 'item'),
)

我写了基本测试并将其放入 ./test/test_example.py
import unittest
from django.test import Client

class PagesTestCase(unittest.TestCase): 
    def setUp(self):
        self.client = Client()

    def test_itemlist(self):        
        response = self.client.get('/myapp/example1/')
        self.assertEqual(response.status_code, 200)

    def test_item(self):        
        response = self.client.get('/myapp/example1/100100/')
        self.assertEqual(response.status_code, 200)

我像这样从 shell 运行这个测试:
cd ./tests
python manage.py test

第一个测试运行正常,但第二个总是失败,并显示“404 not found”状态代码。

这两个网址在浏览器中都可以正常工作。

另外,我试过这个:
cd ./
python manage.py shell
>>> from django.test.client import Client
>>> c = Client()
>>> r = c.get('/myapp/example1/100100/')
>>> r.status_code
200

我只是不知道如何正确运行这些测试。似乎没有作为参数传递到 View 中的模式对我有用。但是 django.test.client 可以正确找到所有固定的 url。

谢谢!

编辑:我刚刚发现 myproject/myapp/views.py 中的 404 触发了

有一个代码:
def item(request, item_id):
    try:
        item = Item.objects.get(pk = int(item_id))
    except (ValueError, Item.DoesNotExist):     
        raise Http404

这是 Item.DoesNotExist 异常。我不知道,为什么找不到那个项目?

最佳答案

除了使用reverse ,如果预期模型在测试数据库中不可用(如其中一条评论中所述),您可以获得 404。你也应该使用 Django 的 TestCase而不是 python 的 unittest因为前者从后者继承,但使与数据库的交互更容易(除其他外)。
设置测试数据的示例:

from django.test import TestCase
from django.urls import reverse

# Or whatever your object is.
from .models import Item


class ItemViewsTestCase(TestCase):
    """Tests for Item views."""
    @classmethod
    def setUpTestData(cls):
        """Set up test data available for all tests in this class."""
        cls.item = Item.objects.create(name='Testing')

    def test_item_list_view(self):
        # Note, self.client we get for free from Django's TestCase.
        response = self.client.get(reverse('itemlist'))
        self.assertEqual(response.status_code, 200)

    def test_item_detail_view(self):
        # This url pattern expects an Item.id so use the item we set up.
        url = reverse('item', args=[self.item.id])
        response = self.client.get(url)
        self.assertEqual(response.status_code, 200)

关于python - django.test.client 在现有 url 上出现 404 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28173071/

相关文章:

python - 在 Python 中加载 dll 时出现 Windows 错误 1114

python - 导入错误 : No module named 'cv2' Python3

python - Django split Models in différents models.py 文件给我导入循环

python - Django 查询外键返回列表 "grouped by"

angularjs - 使用 multiCapabilites 时的多个 onPrepare 或动态登录参数

database - MSTest 单元测试和数据库访问,无需接触实际数据库

python:指定观察周围的窗口

python - 在 Amazon Linux 2 上安装 AWS CDK

python - 将默认 PK slug 替换为 ModelViewSet 的多个查找字段

java - 如何在 JUnit5 中实现自定义运行器