实战接口开发:python + flask + mysql + redis(根据反馈,持续细化更新。。。)
前言
自动化没练习的项目怎么办?
自动化已经成为测试的必备技能之一了,所以,很多想跳槽的测试朋友都在自学,特别是最实用的接口自动化,
但是很多人因为没有可以练手的项目而苦恼,最终导致缺乏实战经验,其实,完全可以自己开发个简单项目练手,
本文,就带大家开发个简单的项目,只包含后端接口,使用的技术栈是:python + flask + mysql + redis,为了练习python基础,没有使用组件。
python:很容易入门的语言,三方库非常丰富,不用我们自己造轮子
flask:轻量级的web开发框架,快速上手
mysql:主流的数据库,本项目用于存储用户信息,python中可以用pymysql库操作msyql,flask中也有对应的组件
redis:主流的缓存数据库,本项目用于存储token,python中可以用redis库操作redis
开发环境准备
相关的安装包等资料,在【测试提升圈】学习周计划网盘中。
windows下安装python(只安装3.x版本):https://www.cnblogs.com/uncleyong/p/10778792.html
windows下安装配置pycharm:请自行百度
linux基础:《鸟哥的Linux私房菜》,常用命令:https://www.cnblogs.com/uncleyong/p/10637238.html
安装linux虚拟机(当然,你也可以考虑买云服务器):https://www.cnblogs.com/uncleyong/p/10740005.html
下面是我安装的linux版本
mysql安装(建议linux下):https://www.cnblogs.com/uncleyong/p/10739530.html
客户端工具Navicat安装:https://www.cnblogs.com/uncleyong/p/10823925.html
redis安装(建议linux下):https://www.cnblogs.com/uncleyong/p/9882843.html
mysql和redis建议在linux下安装,既可以练习linux命令,又可以练习环境搭建,项目开发完后,也可以部署到linux服务器上
部分基础回顾
https://www.cnblogs.com/uncleyong/p/12230502.html
实战1:demo项目开发(开发几个涉及关联的接口)
interface_demo项目需求
用户信息管理,可以注册、登录、添加用户、删除用户
注册:任何用户可以注册,对用户提交的注册信息进行校验,返回对应的信息,其中:
用户名:必填,唯一
密码:必填,只能6-12位,入库是加盐加密
真实名:必填
性别:非必填,只能0(male)或者1(female)
电话:必填,唯一,满足电话要求,数字,且11位
登录:用户登录,成功,则保存token到redis,其中:
用户名:必填
密码:必填
如果登录成功,对用户名加时间戳的字符串进行md5加密,生成的值作为token,然后将用户名作为key,token作为value,存入redis,且设置失效时间
添加用户:只能是管理员且登录成功后,才可以添加用户
token:必填,登录成功返回的token
添加者:必填
用户名:必填,唯一
真实名:必填
性别:非必填,只能0(male)或者1(female)
电话:必填,唯一,满足电话要求,数字,且11位
密码:默认是123456,不填
删除用户:只能是管理员且登录成功后,才可以删除用户
略
数据库表设计、接口开发实现(含源码)
测试提升圈专属版本:https://www.cnblogs.com/uncleyong/protected/p/12046058.html
本项目用到了主流技术栈,这些都是测试必备的:python、flask、redis基础、mysql基础、git基础、shell基础、linux、jenkins等
你也可以开发几个mock接口用于练习,推荐用flask或者springboot
比如是flask的话:
return jsonify({"code":9410,"msg":"用户名或密码不正确"})
实战2:demo项目测试(接口功能测试,用jmeter和postman)
实战1中,已经开发好了我们练习的项目,我们先对接口进行功能测试,
接口功能测试,我们最常用的工具是jmeter和postman
jmeter,参考:https://mp.weixin.qq.com/s/msowzis-ktMk2PL_yM_J6g
postman,参考:https://www.cnblogs.com/uncleyong/p/11268846.html
实战3:自动化测试框架设计、开发、demo项目自动化测试
实现了关联、测试数据分离等等,拿来即可使用:
测试提升圈专属版本:https://www.cnblogs.com/uncleyong/p/12046070.html
多个版本的自动化测试框架,例如:
unittest + 关联 + excle + ddt
自己造轮子(未使用unittest、pytest等)
实战4:自动化测试持续集成环境搭建(自动化构建、部署、测试、报告)
开发提交代码到远程仓库后,触发自动化构建→自动化部署→自动化测试...
自动化持续集成环境搭建(上):git + maven+ jenkins:https://www.cnblogs.com/uncleyong/protected/p/10821832.html
自动化持续集成环境搭建(下):git + maven+ jenkins
测试提升圈专属版本:https://www.cnblogs.com/uncleyong/protected/p/12229900.html
对外分享版本:https://mp.weixin.qq.com/s/CVrn2XuL3lQj9slUqx73_A
docker版后续更新。
后记
进阶提升,性能 or 测开?
通过这几个实战,相信认真实操过的朋友肯定收获不少,不管是编码,还是linux命令及环境搭建,或者是相关的工具使用;
总之,自动化只是回归,不要满足于自动化,多学一个其它测试方向,会更有竞争力;
接下来你需要进阶的方向可能是性能测试、或者测试开发,关于二者该怎么选择,可以参考:https://www.cnblogs.com/uncleyong/p/11995605.html
性能测试:从0到实战
https://www.cnblogs.com/uncleyong/p/12311432.html
实战接口开发:python + flask + mysql + redis(根据反馈,持续细化更新。。。)的更多相关文章
- demo项目开发(Python+flask+mysql+redis只包含后端接口)
[demo项目开发需求] 用户信息管理,可以注册.登录.添加用户.删除用户 注册:任何用户可以注册,对用户提交的注册信息进行校验,返回对应的信息,其中: 用户名:必填,唯一 密码:必填,只能6-12位 ...
- Python+Flask+MysqL的web建设技术过程
一.前言(个人学期总结) 个人总结一下这学期对于Python+Flask+MysqL的web建设技术过程的学习体会,Flask小辣椒框架相对于其他框架而言,更加稳定,不会有莫名其妙的错误,容错性强,运 ...
- Python+Flask+MysqL的web技术建站过程
1.个人学期总结 时间过得飞快,转眼间2017年就要过去.这一年,我学习JSP和Python,哪一门都像一样新的东西,之前从来没有学习过. 这里我就用我学习过的Python和大家分享一下,我是怎么从一 ...
- 个人学期总结及Python+Flask+MysqL的web建设技术过程
一个学期即将过去,我们也迎来了2018年.这个学期,首次接触了web网站开发建设,不仅是这门课程,还有另外一门用idea的gradle框架来制作网页. 很显然,用python语言的flask框架更加简 ...
- 前端和后端的数据交互(jquery ajax+python flask+mysql)
上web课的时候老师布置的一个实验,要求省市连动,基本要求如下: 1.用select选中一个省份. 2.省份数据传送到服务器,服务器从数据库中搜索对应城市信息. 3.将城市信息返回客户,客户用sele ...
- python3.4学习笔记(二十五) Python 调用mysql redis实例代码
python3.4学习笔记(二十五) Python 调用mysql redis实例代码 #coding: utf-8 __author__ = 'zdz8207' #python2.7 import ...
- Python操作MySQL+Redis+MongoDB
1-1 python操作三大主流数据库导学篇 1-2 数据库简介 1-3 MySQL简介 2-1 MySQL安装及配置 2-2 MySQL图形化管理工具 2-3 SQL语法基础-创建并使用数据库 2- ...
- 从docker到docker-compose部署一个nginx+flask+mysql+redis应用
目的是把一个flask项目的mysql数据库.redis数据库.flask应用.nginx服务分别装到四个容器中,然后用docker-compose命令同时启动与关闭 一.安装docker Docke ...
- java 微信自定义菜单 java微信接口开发 公众平台 SSM redis shiro 多数据源
A 调用摄像头拍照,自定义裁剪编辑头像,头像图片色度调节B 集成代码生成器 [正反双向](单表.主表.明细表.树形表,快速开发利器)+快速表单构建器 freemaker模版技术 ,0个代码不用写,生成 ...
随机推荐
- 【oracle】获取字符串长度
lengthb(string)计算string所占的字节长度:返回字符串的长度,单位是字节 length(string)计算string所占的字符长度:返回字符串的长度,单位是字符
- AGC008E Next or Nextnext(组合计数,神奇思路)
神仙题. 排列计数,一种常见的做法是 \(i\) 向 \(p_i\) 连边. 然而这里这个就逼迫我们只能从 \(i\) 向 \(a_i\) 连边. 不过没关系,考虑从 \(i\) 向 \(p_i\) ...
- Harbor + Https 部署
关闭防火墙和selinux systemctl stop firewalld sed -i 's/SELINUX=.*/SELINUX=disabled/g' /etc/sysconfig/selin ...
- 物联网架构成长之路(40)-Bladex开发框架入门
0. 前言 前一小节,讲了如何入门,这里就简单讲一下如何自定义查询和权限控制配置. 1. 配置多租户 如果要启用该表的多租户功能,需要在application.yml 这里配置. 2. 配置模糊匹配 ...
- Kubernetes PV与PVC的关系
Kubernetes PV与PVC的关系 PersistenVolume(PV):对存储资源创建和使用的抽象,使得存储作为集群中的资源管理,分为有静态与动态.PersistentVolumeClaim ...
- Abap内表
什么是内表:内表是内存中建立的一个临时表,你可以在程序运行时对表中的数据进行,插入,修改,删除等操作,程序跑完了,就会被释放. 定义类型:通过types开头定义 TYPES: BEGIN OF lin ...
- rsync性能终极优化【Optimize rsync performance】
前言 将文件从一台计算机同步或备份到另一台计算机的快速简便的方法是使用rsync.我将介绍通常用于备份数据的命令行选项,并显示一些选项以极大地将传输速度从大约20-25 MB / s加快到90 MB ...
- Jenkins配置LDAP认证
managerdn即为连接到AD的账号
- Socket与WebSocket以及http与https重新总结
Socket与WebSocket以及http与https重新总结 一.Socket 网络中的Socket是一个抽象的接口 ,而是为了方便使用TCP或UDP而抽象出来的一层 ,可以理解为网络中连接的两端 ...
- MySQL 的一些批处理
执行 SQL 脚本文件(https://blog.csdn.net/vebasan/article/details/7619911): mysql –u root –p 123456 < scr ...