REST架构中,后端如何写接口及单元测试

本文探讨了在REST架构中后端如何编写接口和进行单元测试。整合测试利用Django或Flask等框架的测试客户端进行,测试接口逻辑、ORM与数据库交互。单元测试则使用模拟技术如unittest.mock,测试单个函数功能,涉及ORM数据模型层和视图层的行为测试,确保代码质量、可维护性和易定位错误。
摘要由CSDN通过智能技术生成

后端举例,接口测试在实际应用中编写最容易,编写速度最快的就是整合测试。
1)整合测试测试接口逻辑与数据库ORM等多个功能,可以用到web开发框架(如Django、Flask等)自带的测试客户端和测试类(如Django的TestCase)。
2)不管是接口测试用例还是单元测试用例,其主要测试方向都是集中测试指定的接口或函数功能上”做什么”。如,对于REST型接口而言,主要测试的方面包括:传入有效和无效参数、接口返回的预期的状态码、返回与前端约定的数据格式,数据库数据异常情况下的接口数据处理等。

代码举例如下

import json
from django.test import TestCase

from lists.models import List, Item
from lists.forms import DUPLICATE_ITEM_ERROR, EMPTY_ITEM_ERROR


class ListAPITest(TestCase):
    base_url = "/api/lists/{}/"

    def test_get_returns_json_200(self):
        ''' 测试get接口返回了200的json '''
        list_ = List.objects.create()
        response = self.client.get(self.base_url.format(list_.id))
        self.assertEqual(response.status_code, 200)
        self.assertEqual(response["content-type"], "application/json")

    def test_get_returns_items_for_correct_list(self):
        ''' 测试api返回指定清单的所有待办事项 '''
        other_list = List.objects.create()
        Item.objects.create(list=other_list, text="待办事项1")
        our_list = List.objects.create()
        item1 = Item.objects.create(list=our_list, text="待办事项1")
        item2 = Item.objects.create(list=our_list, text="待办事项2")
        response = self.client.get(self.base_url.format(our_list.id))
        self.assertEqual(
            json.loads(response.content.decode("utf8"))
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值