实战接口开发: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个代码不用写,生成 ...
随机推荐
- 浅谈字符串Hash
浅谈字符串Hash 本篇随笔讲解Hash(散列表)的一个重要应用:字符串Hash. 关于Hash Hash是一种数据结构,叫做Hash表(哈希表),也叫散列表.关于Hash的实现,其实与离散化颇为类似 ...
- python中实现单例模式
单例模式的目的是一个类有且只有一个实例对象存在,比如在复用类的过程中,可能重复创建多个实例,导致严重浪费内存,此时就适合使用单例模式. 前段时间需要用到单例模式,就称着机会在网上找了找,有包含了__n ...
- docker 创建mysql容器并且绑定到本地navicat
docker pull mysql docker run --name mysql -itd -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root1234 mysql do ...
- Linux学习笔记-第14天 老朋友相见
熟悉的Apache,这次换了种方式和你见面.希望我能更懂你.
- Vue v-for操作与computed结合功能
<!doctype html> <html lang="en"> <head id="head"> <meta cha ...
- github上计算String相似度好的项目
项目中包含了杰卡德NGram.cosin夹角.最长公共子序列.边际距离等常用的相似度算法. https://github.com/tdebatty/java-string-similarity
- IOI游记
你竟然点进来了?那你的脑袋可能和我的一样智障QAQ. 啥也没有,闲的没事挖的坑,不要在意,没啥可读的. 权当是一个目标吧(尽管几乎不可能成真),倘若未来(无数年后),我真的站在IOI的赛场上,那我可以 ...
- NETCore下IConfiguration和IOptions的用法(转载)
原文:https://www.jianshu.com/p/b9416867e6e6 新建一个NETCore Web API项目,在Startup.cs里就会开始使用IConfiguration和IOp ...
- win7 下docker 镜像加速
打开 Kitematic 运行 docker cli 注册镜像 https://www.daocloud.io/mirror#accelerator-doc 上有镜像地址 sudo sed -i &q ...
- Kubernetes 动态PV使用
Kubernetes 动态PV使用 Kubernetes支持动态供给的存储插件:https://kubernetes.io/docs/concepts/storage/storage-classes/ ...