在现在的软件开发过程中,特别是app的部分,需要的很多数据以及内容,都是来自server端的API,但是不能保证

在客户端开发的时候,api在server端已经开发完成,专门等着前端来调用,理想的情况是前端在开发的时候,已经有人写

好了接口,直接调用就可以了,但是这仅仅是理想的情况,很多时候,现实总是比理想多一层思考和磨难,如果在前端开发

的时候,提供api的同学没有提供,那么怎么办?等待还是自己先开发,等待肯定是愚蠢的做法,那么自己开发怎么来解决

api提供数据的这个问题,那么使用mock就可以很好的解决,什么是mock?mock简单的理解就是开发在开发的过程中,

需要依赖一部分的接口,但是对方没有提供或者环境等等情况,总之是没有,那么开发使用mock server自己来mock

数据,方便自己正常的进行开发和对编写的功能进行自测。

https://github.com/dreamhead/moco地址中可以下载到moco-runner-0.12.0-standalone.jar,下载下来

就是一个jar,在该地址中,作者对这部分有详细的说明和启动mock server方法,这里不在重复的再次说明。下来我们

简单的编写一个登录的,见编写的login.json字符串,一个是登录请求,一个是根据车牌查询停车费的请求:

[  {    "request":    {      "method":"post",      "uri":"/login",      "json":      {        "username":"admin",        "password":"admin",        "roleID":22      }    },    "response":    {      "file":"login_response.json"    }  },

  {    "request":    {      "method":"post",      "uri":"/parkinside",      "json":      {        "token":"asdgfhh32456asfgrsfss",        "vpl":"AJ3585"      }    },    "response":    {      "file":"parkinside.json"    }  }]

在UI或者接口的自动化测试中,我们知道在TDD的模式中,对数据进行分离,这样也是为了维护的方便,这样的目的是为了后期自动化测试用例的扩展性,和它的易维护性。

login_response.json文件的内容:

{
  "username":"wuya",
  "userID":22,
  "token":"asdgfhh32456asfgrsfss"
}

parkinside.json文件的内容:

{
  "vplInfo":
  {
    "userID":22,
    "username":"wuya",
    "vpl":"京AJ3585"
  },
  "Parking time long":"20小时18分钟",
  "Parking fee":"20$"
}

在运行命令前,最好让mock server与编写的login.json文件是在同一个目录下,见执行的命令:

java -jar  moco-runner-0.10.0-standalone.jar http -p 12306 -c login.json

在如上的命令中,java -jar  moco-runner-0.10.0-standalone.jar是启动jar,没什么可说的,http表示进行的是http协议,

-p后面跟的是端口号,这里端口号指的是12306,-c后面跟编写的json文件,这里是login.json,见执行如上的命令后出现的

信息(切记无任何的错误信息表示OK,如果有错误,慢慢的进行检查错误),见截图:

OK,下来我们使用postman来验证下,我们mock的登录接口是不是OK的,见postman中填写的信息,见截图:

header为:

  • Content-Length →63
  • Content-Type →application/json

下面我们通过python语言,来对如上的二个接口进行实战的操作,切记parkinside的接口是在登录之后才可以操作的业务,未登录操作该业务,返回502无效的

token,见实现的代码:

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import  unittest
import  requests

class MockTest(unittest.TestCase):
    def setUp(self):
        self.url='http://localhost:12306'

    def tearDown(self):
        pass

    def test_login(self,url='/login'):
        '''验证登录的接口'''
        data={
            "username":"admin",
            "password":"admin",
            "roleID":22
        }
        r=requests.post(self.url+url,json=data)
        self.assertEqual(r.status_code,200)
        self.assertEqual(r.json()['username'],'wuya')

    def getToken(self,url='/login'):
        '''登录成功后获取token'''
        data={
            "username":"admin",
            "password":"admin",
            "roleID":22
        }
        r=requests.post(self.url+url,json=data)
        return r.json()['token']

    def test_parkingside(self,url='/parkinside'):
        '''验证查询停车时长接口'''
        data={
            "token":self.getToken(),
            "vpl":"AJ3585"
        }
        r=requests.post(self.url+url,json=data)
        self.assertEqual(r.status_code,200)
        self.assertEqual(r.json()['Parking time long'],u'20小时18分钟')
        self.assertEqual(r.json()['Parking fee'], u'20$')

if __name__=='__main__':
    unittest.main(verbosity=2)

最新文章

  1. Swift 定义函数 参数 返回值
  2. 根据Excel的内容和word模板生成对应的word文档
  3. macosx zsh下安装rvm和ruby
  4. SELECT时为何要加WITH(NOLOCK)
  5. poj1244Slots of Fun
  6. C# SQL增删查改
  7. 摄像头(4)用Camera和SurfaceView自定义拍照程序
  8. 英语阅读积累<一>
  9. 使用spring的jdbcTemplate-----用JDBC模板查询数据库
  10. 深入Spring之web.xml
  11. Kafka 0.8源码分析—ZookeeperConsumerConnector
  12. window下MongoDB的配置与安装
  13. Python 解LeetCode:680. Valid Palindrome II
  14. 《大型网站系统与Java中间件实现》有感
  15. JavaWeb项目:在线评测系统
  16. js计算总页数
  17. linux出现tmp空间满的情况解决
  18. 动态规划之91 decode ways
  19. JS 冒泡排序法 输出最大值
  20. 关于Python matplotlib显示汉字乱码问题

热门文章

  1. _bzoj1257 [CQOI2007]余数之和sum【小技巧】
  2. _bzoj1911 [Apio2010]特别行动队【斜率优化dp】
  3. Voting CodeForces - 749C
  4. 今天发现一个汉字转换成拼音的模块,记录一下,直接pip install xpinyin即可
  5. adb的含义
  6. C#: static关键字的作用(转)
  7. mybatis通过插件方式实现读写分离
  8. MySQL 当记录不存在时insert,当记录存在时更新
  9. CF749D Leaving Auction
  10. C3P0连接池工具类实现步骤及方法