Commit 90b1365a by sanshi

用户模块完成

parent d374c92a
...@@ -28,11 +28,15 @@ class MembersDelete(object): ...@@ -28,11 +28,15 @@ class MembersDelete(object):
self.local_json = {} self.local_json = {}
self.token = None
self.memberIds = None self.memberIds = None
self.api = UtilsRequest() self.api = UtilsRequest()
def get_response(self): def get_response(self):
base = ApiBase()
base.dict_add_key(_key="token", value=self.token)
self._headers = base._json
base = ApiBase() base = ApiBase()
base.dict_add_key(_key="memberIds", value=self.memberIds) base.dict_add_key(_key="memberIds", value=self.memberIds)
...@@ -40,4 +44,4 @@ class MembersDelete(object): ...@@ -40,4 +44,4 @@ class MembersDelete(object):
self.local_json = base._json self.local_json = base._json
self._json = self.local_json self._json = self.local_json
self.response = self.api.post(url=self._url, json=self._json) self.response = self.api.post(url=self._url, headers=self._headers, json=self._json)
...@@ -28,18 +28,20 @@ class MembersGet(object): ...@@ -28,18 +28,20 @@ class MembersGet(object):
self.local_json = {} self.local_json = {}
self.token = None
self.name = None self.name = None
self.status = None self.status = None
self.api = UtilsRequest() self.api = UtilsRequest()
def get_response(self): def get_response(self):
base = ApiBase()
base.dict_add_key(_key="token", value=self.token)
self._headers = base._json
base = ApiBase() base = ApiBase()
base.dict_add_key(_key="name", value=self.name) base.dict_add_key(_key="name", value=self.name)
base.dict_add_key(_key="status", value=self.status) base.dict_add_key(_key="status", value=self.status)
self.local_json = base._json self._params = base._json
self.response = self.api.get(url=self._url, headers=self._headers, params=self._params)
self._json = self.local_json
self.response = self.api.post(url=self._url, json=self._json)
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-11-22
from __future__ import division
from WorkCase import CaseBase
from WorkUtils.UtilsLog import UtilsLog
from WorkUtils.UtilsDataBase import UtilsDataBase
from WorkUtils.UtilsResponse import UtilsResponse
from WorkApi.APP.Api.api_login import ApiLogin
from WorkApi.APP.Members.members_create import MembersCreate
from WorkApi.APP.Members.members_delete import MembersDelete
from WorkData.Argus.members import DataMembers
import allure
@allure.feature("测试模块:members.delete")
class TestMembersDelete(object):
log = UtilsLog()
env = CaseBase().app_environment
host = env["host"]
db_url = env["db_url"]
db_port = env["db_port"]
db_user = env["db_user"]
db_pw = env["db_pw"]
db_base = env["db_base"]
login_name = "SS测试用户名"
base_id = 10
base_password = "123456"
base_name = "SS自动化测试用户名--删除用户"
@classmethod
def setup_class(cls):
cls.log.debug("开始执行测试套件.......")
session = UtilsDataBase().conn_mysql(db_url=cls.db_url, db_port=cls.db_port, db_base=cls.db_base, db_user=cls.db_user, db_pw=cls.db_pw)
DataMembers().delete_like_name(session=session, name=cls.base_name)
@classmethod
def teardown_class(cls):
cls.log.debug("结束执行测试套件.......")
def setup_method(self):
self.log.debug("测试用例执行开始...")
self.update_members_del_flag(members_id=self.base_id, value=0)
self.update_members_status(members_id=self.base_id, value=0)
def teardown_method(self):
self.log.debug("测试用例执行结束...")
self.update_members_del_flag(members_id=self.base_id, value=0)
self.update_members_status(members_id=self.base_id, value=0)
@allure.step("调用接口:api.login")
def api_login(self, name=None, password=None):
api = ApiLogin(_host=self.host)
api.name = name
api.password = password
api.get_response()
return api.response
@allure.step("调用接口:members.create")
def members_create(self, token=None, name=None, position=None, role=None, password=None,
phone=None, email=None, wechatUrl=None, dingdingUrl=None, remark=None):
api = MembersCreate(_host=self.host)
api.token = token
api.name = name
api.position = position
api.role = role
api.password = password
api.phone = phone
api.email = email
api.wechatUrl = wechatUrl
api.dingdingUrl = dingdingUrl
api.remark = remark
api.get_response()
return api.response
@allure.step("调用接口:members.delete")
def members_delete(self, token=None, memberIds=None):
api = MembersDelete(_host=self.host)
api.token = token
api.memberIds = memberIds
api.get_response()
return api.response
@allure.step("创建测试数据")
def get_base_token(self):
response = self.api_login(name=self.login_name, password=self.base_password)
self.token = UtilsResponse().get_data(response=response)
@allure.step("连接数据库:Argus")
def db_session(self):
session = UtilsDataBase().conn_mysql(db_url=self.db_url, db_port=self.db_port, db_base=self.db_base, db_user=self.db_user, db_pw=self.db_pw)
return session
@allure.step("新增表数据:members")
def insert_one(self, name=None, role=None, password=None):
session = self.db_session()
sql = DataMembers().insert_one(session=session, name=name, role=role, password=password)
return sql
@allure.step("查询表:members")
def select_members(self, members_id=None, name=None, role=None, status=None, del_flag=None):
session = self.db_session()
sql = DataMembers().select_all_from_allKeys(session=session, _id=members_id, name=name, role=role,
status=status, del_flag=del_flag)
return sql
@allure.step("更新表数据:members -- del_flag")
def update_members_del_flag(self, members_id=None, value=None):
session = self.db_session()
sql = DataMembers().update_del_flag(session=session, _id=members_id, value=value)
return sql
@allure.step("更新表数据:members -- status")
def update_members_status(self, members_id=None, value=None):
session = self.db_session()
sql = DataMembers().update_status(session=session, _id=members_id, value=value)
return sql
@allure.step("更新表数据:members -- password")
def update_members_password(self, members_id=None, value=None):
session = self.db_session()
sql = DataMembers().update_password(session=session, _id=members_id, value=value)
return sql
@allure.step("校验查询结果")
def check_select(self, members_id, name, position, role, password, phone, email, wechatUrl, dingdingUrl, remark, del_flag):
sql = self.select_members(members_id=members_id)
for x, y in enumerate(sql):
assert y.name == name
assert y.position == position
assert y.role == role
assert y.password == password
assert y.phone == phone
assert y.email == email
assert y.wechat_url == wechatUrl
assert y.dingding_url == dingdingUrl
assert y.remark == remark
assert y.del_flag == del_flag
assert y.status == 0
@allure.step("断言返回结果")
def check_code(self, response, code):
_code = UtilsResponse().get_code(response=response)
assert _code == code
@allure.step("断言返回结果数据")
def check_msg(self, response, msg):
_msg = UtilsResponse().get_msg(response=response)
assert _msg == msg
@allure.title("members.delete:token未传")
@allure.story("删除用户:token未传")
@allure.severity("blocker")
def test_case_01(self):
self.get_base_token()
response = self.members_delete()
self.check_code(response=response, code=2001)
self.check_msg(response=response, msg="无token,请重新登录")
@allure.title("members.delete:token的用户已删除")
@allure.story("删除用户:token的用户已删除")
@allure.severity("blocker")
def test_case_02(self):
self.get_base_token()
self.update_members_del_flag(members_id=self.base_id, value=1)
response = self.members_delete(token=self.token)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("members.delete:token的用户已禁用")
@allure.story("删除用户:token的用户已禁用")
@allure.severity("blocker")
def test_case_03(self):
self.get_base_token()
self.update_members_status(members_id=self.base_id, value=1)
response = self.members_delete(token=self.token)
self.check_code(response=response, code=2003)
self.check_msg(response=response, msg="账户已被禁用")
@allure.title("members.delete:无参数调用")
@allure.story("删除用户:无参数调用")
def test_case_04(self):
self.get_base_token()
# name = self.base_name + "04"
# response = self.members_create(token=self.token, name=name, password=self.base_password, role=0)
# memberId = UtilsResponse().get_data(response=response)
response = self.members_delete(token=self.token)
self.check_code(response=response, code=100)
self.check_msg(response=response, msg="Required List parameter 'memberIds' is not present")
@allure.title("members.delete:memberIds=[]")
@allure.story("删除用户:memberIds=[]")
def test_case_05(self):
self.get_base_token()
# name = self.base_name + "05"
# response = self.members_create(token=self.token, name=name, password=self.base_password, role=0)
# memberId = UtilsResponse().get_data(response=response)
response = self.members_delete(token=self.token, memberIds=[])
self.check_code(response=response, code=100)
@allure.title("members.delete:删除单个用户")
@allure.story("删除用户:删除单个用户")
@allure.severity("blocker")
def test_case_06(self):
self.get_base_token()
name = self.base_name + "06"
response = self.members_create(token=self.token, name=name, password=self.base_password, role=0)
memberId = UtilsResponse().get_data(response=response)
response = self.members_delete(token=self.token, memberIds=[memberId])
self.check_code(response=response, code=0)
self.check_select(members_id=memberId, name=name, position=None, role=0, password=self.base_password, phone=None,
email=None, wechatUrl=None, dingdingUrl=None, remark=None, del_flag=1)
@allure.title("members.delete:删除多个用户")
@allure.story("删除用户:删除多个用户")
def test_case_06(self):
self.get_base_token()
name_1 = self.base_name + "061"
name_2 = self.base_name + "062"
name_3 = self.base_name + "063"
response = self.members_create(token=self.token, name=name_1, password=self.base_password, role=0)
memberId_1 = UtilsResponse().get_data(response=response)
response = self.members_create(token=self.token, name=name_2, password=self.base_password, role=0)
memberId_2 = UtilsResponse().get_data(response=response)
response = self.members_create(token=self.token, name=name_3, password=self.base_password, role=0)
memberId_3 = UtilsResponse().get_data(response=response)
response = self.members_delete(token=self.token, memberIds=[memberId_1, memberId_2, memberId_3])
self.check_code(response=response, code=0)
self.check_select(members_id=memberId_1, name=name_1, position=None, role=0, password=self.base_password, phone=None,
email=None, wechatUrl=None, dingdingUrl=None, remark=None, del_flag=1)
self.check_select(members_id=memberId_2, name=name_2, position=None, role=0, password=self.base_password, phone=None,
email=None, wechatUrl=None, dingdingUrl=None, remark=None, del_flag=1)
self.check_select(members_id=memberId_3, name=name_3, position=None, role=0, password=self.base_password, phone=None,
email=None, wechatUrl=None, dingdingUrl=None, remark=None, del_flag=1)
if __name__ == "__main__":
from WorkUtils.UtilsPyTest import UtilsPyTest
from WorkUtils.UtilsCmd import UtilsCmd
import os
# 执行自动化测试用例
case_info = os.path.split(__file__)
case = UtilsCmd().pytest_cmd()
r = UtilsPyTest(case=case, case_info=case_info)
r.run_main()
# a = TestMembersDelete()
# a.setup_class()
# a.test_case_06()
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-11-20
from __future__ import division
from WorkCase import CaseBase
from WorkUtils.UtilsLog import UtilsLog
from WorkUtils.UtilsDataBase import UtilsDataBase
from WorkUtils.UtilsResponse import UtilsResponse
from WorkApi.APP.Api.api_login import ApiLogin
from WorkApi.APP.Members.members_create import MembersCreate
from WorkApi.APP.Members.members_get import MembersGet
from WorkData.Argus.members import DataMembers
import allure
# allure.label("")
@allure.feature("测试模块:members.get")
class TestMembersGet(object):
log = UtilsLog()
env = CaseBase().app_environment
host = env["host"]
db_url = env["db_url"]
db_port = env["db_port"]
db_user = env["db_user"]
db_pw = env["db_pw"]
db_base = env["db_base"]
login_name = "SS测试用户名"
base_id = 10
base_password = "123456"
base_name = "SS自动化测试用户名--列表"
@classmethod
def setup_class(cls):
cls.log.debug("开始执行测试套件.......")
session = UtilsDataBase().conn_mysql(db_url=cls.db_url, db_port=cls.db_port, db_base=cls.db_base, db_user=cls.db_user, db_pw=cls.db_pw)
DataMembers().delete_like_name(session=session, name=cls.base_name)
@classmethod
def teardown_class(cls):
cls.log.debug("结束执行测试套件.......")
def setup_method(self):
self.log.debug("测试用例执行开始...")
self.update_members_del_flag(members_id=self.base_id, value=0)
self.update_members_status(members_id=self.base_id, value=0)
def teardown_method(self):
self.log.debug("测试用例执行结束...")
self.update_members_del_flag(members_id=self.base_id, value=0)
self.update_members_status(members_id=self.base_id, value=0)
@allure.step("调用接口:api.login")
def api_login(self, name=None, password=None):
api = ApiLogin(_host=self.host)
api.name = name
api.password = password
api.get_response()
return api.response
@allure.step("调用接口:members.create")
def members_create(self, token=None, name=None, position=None, role=None, password=None,
phone=None, email=None, wechatUrl=None, dingdingUrl=None, remark=None):
api = MembersCreate(_host=self.host)
api.token = token
api.name = name
api.position = position
api.role = role
api.password = password
api.phone = phone
api.email = email
api.wechatUrl = wechatUrl
api.dingdingUrl = dingdingUrl
api.remark = remark
api.get_response()
return api.response
@allure.step("调用接口:members.get")
def members_get(self, token=None, name=None, status=None):
api = MembersGet(_host=self.host)
api.token = token
api.name = name
api.status = status
api.get_response()
return api.response
@allure.step("创建测试数据")
def get_base_token(self):
response = self.api_login(name=self.login_name, password=self.base_password)
self.token = UtilsResponse().get_data(response=response)
@allure.step("连接数据库:Argus")
def db_session(self):
session = UtilsDataBase().conn_mysql(db_url=self.db_url, db_port=self.db_port, db_base=self.db_base, db_user=self.db_user, db_pw=self.db_pw)
return session
@allure.step("新增表数据:members")
def insert_one(self, name=None, role=None, password=None):
session = self.db_session()
sql = DataMembers().insert_one(session=session, name=name, role=role, password=password)
return sql
@allure.step("查询表:members")
def select_members(self, members_id=None, name=None, role=None, status=None, del_flag=None):
session = self.db_session()
sql = DataMembers().select_all_from_allKeys(session=session, _id=members_id, name=name, role=role,
status=status, del_flag=del_flag)
return sql
@allure.step("更新表数据:members -- del_flag")
def update_members_del_flag(self, members_id=None, value=None):
session = self.db_session()
sql = DataMembers().update_del_flag(session=session, _id=members_id, value=value)
return sql
@allure.step("更新表数据:members -- status")
def update_members_status(self, members_id=None, value=None):
session = self.db_session()
sql = DataMembers().update_status(session=session, _id=members_id, value=value)
return sql
@allure.step("更新表数据:members -- password")
def update_members_password(self, members_id=None, value=None):
session = self.db_session()
sql = DataMembers().update_password(session=session, _id=members_id, value=value)
return sql
@allure.step("校验查询结果")
def check_select(self, response, members_id):
import time
data = UtilsResponse().get_data(response=response)
sql = self.select_members(members_id=members_id)
for x, y in enumerate(data["list"]):
for q, w in enumerate(sql):
assert y["name"] == w.name
assert y["roleName"] == "管理员角色"
assert y["createDate"] == time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(w.create_time/1000))
assert y["status"] == w.status
@allure.step("断言返回结果")
def check_code(self, response, code):
_code = UtilsResponse().get_code(response=response)
assert _code == code
@allure.step("断言返回结果数据")
def check_msg(self, response, msg):
_msg = UtilsResponse().get_msg(response=response)
assert _msg == msg
@allure.title("members.get:token未传")
@allure.story("查询用户:token未传")
@allure.severity("blocker")
def test_case_01(self):
self.get_base_token()
response = self.members_get()
self.check_code(response=response, code=2001)
self.check_msg(response=response, msg="无token,请重新登录")
@allure.title("members.get:token的用户已删除")
@allure.story("查询用户:token的用户已删除")
@allure.severity("blocker")
def test_case_02(self):
self.get_base_token()
self.update_members_del_flag(members_id=self.base_id, value=1)
response = self.members_get(token=self.token)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("members.get:token的用户已禁用")
@allure.story("查询用户:token的用户已禁用")
@allure.severity("blocker")
def test_case_03(self):
self.get_base_token()
self.update_members_status(members_id=self.base_id, value=1)
response = self.members_get(token=self.token)
self.check_code(response=response, code=2003)
self.check_msg(response=response, msg="账户已被禁用")
@allure.title("members.get:无参数调用")
@allure.story("查询用户:无参数调用")
@allure.severity("blocker")
def test_case_04(self):
self.get_base_token()
response = self.members_get(token=self.token)
self.check_code(response=response, code=0)
@allure.title("members.get:name模糊搜索")
@allure.story("查询用户:name模糊搜索")
def test_case_05(self):
self.get_base_token()
name = self.base_name + "05"
response = self.members_create(token=self.token, name=name, password=self.base_password, role=0)
memberId = UtilsResponse().get_data(response=response)
response = self.members_get(token=self.token, name=self.base_name)
self.check_code(response=response, code=0)
self.check_select(response=response, members_id=memberId)
@allure.title("members.get:name精确搜索")
@allure.story("查询用户:name精确搜索")
def test_case_06(self):
self.get_base_token()
name = self.base_name + "06"
response = self.members_create(token=self.token, name=name, password=self.base_password, role=0)
memberId = UtilsResponse().get_data(response=response)
response = self.members_get(token=self.token, name=name)
self.check_code(response=response, code=0)
self.check_select(response=response, members_id=memberId)
@allure.title("members.get:status=1查询")
@allure.story("查询用户:status=1查询")
def test_case_07(self):
self.get_base_token()
name = self.base_name + "07"
response = self.members_create(token=self.token, name=name, password=self.base_password, role=0)
UtilsResponse().get_data(response=response)
response = self.members_get(token=self.token, name=name, status=1)
self.check_code(response=response, code=0)
assert [] == UtilsResponse().get_data(response=response)["list"]
@allure.title("members.get:status=0查询")
@allure.story("查询用户:status=0查询")
def test_case_08(self):
self.get_base_token()
name = self.base_name + "08"
response = self.members_create(token=self.token, name=name, password=self.base_password, role=0)
memberId = UtilsResponse().get_data(response=response)
response = self.members_get(token=self.token, name=name, status=1)
self.check_code(response=response, code=0)
self.check_select(response=response, members_id=memberId)
if __name__ == "__main__":
from WorkUtils.UtilsPyTest import UtilsPyTest
from WorkUtils.UtilsCmd import UtilsCmd
import os
# 执行自动化测试用例
case_info = os.path.split(__file__)
case = UtilsCmd().pytest_cmd()
r = UtilsPyTest(case=case, case_info=case_info)
r.run_main()
# a = TestMembersGet()
# a.setup_class()
# a.test_case_07()
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment