Commit e61f3fc3 by sanshi

业务类型

parent 0b746091
# -*- coding: utf-8 -*-
# 创建业务类型
# 作者: 陈磊
# 时间: 2019-11-25
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class BusinessesTypeCreate(object):
def __init__(self, _host):
"""
:param _host: 域名
:return:
"""
self.log = UtilsLog()
self.log.info("调用创建业务类型")
self.log.info(self.__class__)
self._host = _host
self._headers = {}
self._path = "/businesses/type/create"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.token = None
self.typeName = None
self.api = UtilsRequest()
def get_response(self):
base = ApiBase()
base.dict_add_key(_key="token", value=self.token)
self._headers = base._json
base = ApiBase()
base.dict_add_key(_key="typeName", value=self.typeName)
self.local_json = base._json
self._json = self.local_json
self.response = self.api.post(url=self._url, headers=self._headers, json=self._json)
# -*- coding: utf-8 -*-
# 删除业务类型
# 作者: 陈磊
# 时间: 2019-11-25
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class BusinessesTypeDelete(object):
def __init__(self, _host):
"""
:param _host: 域名
:return:
"""
self.log = UtilsLog()
self.log.info("调用删除业务类型")
self.log.info(self.__class__)
self._host = _host
self._headers = {}
self._path = "/businesses/type/delete"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.token = None
self.typeIds = None
self.api = UtilsRequest()
def get_response(self):
base = ApiBase()
base.dict_add_key(_key="token", value=self.token)
self._headers = base._json
base = ApiBase()
base.dict_add_key(_key="typeIds", value=self.typeIds)
self.local_json = base._json
self._json = self.local_json
self.response = self.api.post(url=self._url, headers=self._headers, json=self._json)
# -*- coding: utf-8 -*-
# 获取业务类型
# 作者: 陈磊
# 时间: 2019-11-25
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class BusinessesTypeGet(object):
def __init__(self, _host):
"""
:param _host: 域名
:return:
"""
self.log = UtilsLog()
self.log.info("调用获取业务类型")
self.log.info(self.__class__)
self._host = _host
self._headers = {}
self._path = "/businesses/type/get"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.token = None
self.api = UtilsRequest()
def get_response(self):
base = ApiBase()
base.dict_add_key(_key="token", value=self.token)
self._headers = base._json
self.response = self.api.get(url=self._url, headers=self._headers)
# -*- coding: utf-8 -*-
# 编辑业务类型
# 作者: 陈磊
# 时间: 2019-11-25
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class BusinessesTypeUpdate(object):
def __init__(self, _host):
"""
:param _host: 域名
:return:
"""
self.log = UtilsLog()
self.log.info("调用编辑业务类型")
self.log.info(self.__class__)
self._host = _host
self._headers = {}
self._path = "/businesses/type/update"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.token = None
self.id = None
self.typeName = None
self.api = UtilsRequest()
def get_response(self):
base = ApiBase()
base.dict_add_key(_key="token", value=self.token)
self._headers = base._json
base = ApiBase()
base.dict_add_key(_key="id", value=self.id)
base.dict_add_key(_key="typeName", value=self.typeName)
self.local_json = base._json
self._json = self.local_json
self.response = self.api.post(url=self._url, headers=self._headers, json=self._json)
......@@ -26,9 +26,13 @@ class MembersGetRole(object):
self._data = {}
self.response = ""
self.local_json = {}
self.token = None
self.api = UtilsRequest()
def get_response(self):
self.response = self.api.get(url=self._url, params=self._params)
base = ApiBase()
base.dict_add_key(_key="token", value=self.token)
self._headers = base._json
self.response = self.api.get(url=self._url, headers=self._headers, params=self._params)
......@@ -206,7 +206,7 @@ class TestItemsGet(object):
response = self.items_get(hostids=[hostid], output=["hostid", "name"])
self.check_code(response=response, code=0)
self.check_sql(response=response, hostid=hostid)
self.check_sql(response=response)
@allure.title("items.get:limit=1")
@allure.story("查询监控项:limit=1")
......@@ -251,4 +251,5 @@ if __name__ == "__main__":
r.run_main()
# a = TestItemsGet()
# a.test_case_09()
# a.setup_class()
# a.test_case_05()
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-11-25
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.Businesses.Type.businesses_type_create import BusinessesTypeCreate
from WorkData.Argus.members import DataMembers
from WorkData.Argus.businesses_type import DataBusinessesType
import allure
@allure.feature("测试模块:businesses.type.create")
class TestBusinessesTypeCreate(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_typeName = "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)
DataBusinessesType().delete_like_name(session=session, name=cls.base_typeName)
@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 -- 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("调用接口:businesses.type.create")
def businesses_type_create(self, token=None, typeName=None):
api = BusinessesTypeCreate(_host=self.host)
api.token = token
api.typeName = typeName
api.get_response()
return api.response
@allure.step("获取token")
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("查询表:businesses_type")
def select_businesses_type(self, _id=None, name=None):
session = self.db_session()
sql = DataBusinessesType().select_all_from_allKeys(session=session, _id=_id, name=name)
return sql
@allure.step("校验查询结果")
def check_select(self, response, name):
data = UtilsResponse().get_data(response=response)
sql = self.select_businesses_type(_id=data)
for x, y in enumerate(sql):
assert y.name == name
assert x == 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("businesses.type.create:token未传")
@allure.story("创建业务类型:token未传")
@allure.severity("blocker")
def test_case_01(self):
self.get_base_token()
response = self.businesses_type_create()
self.check_code(response=response, code=2001)
self.check_msg(response=response, msg="无token,请重新登录")
@allure.title("businesses.type.create: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.businesses_type_create(token=self.token)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("businesses.type.create: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.businesses_type_create(token=self.token)
self.check_code(response=response, code=2003)
self.check_msg(response=response, msg="账户已被禁用")
@allure.title("businesses.type.create:正常创建")
@allure.story("创建业务类型:正常创建")
@allure.severity("blocker")
def test_case_04(self):
self.get_base_token()
name = self.base_typeName + "04"
response = self.businesses_type_create(token=self.token, typeName=name)
self.check_code(response=response, code=0)
self.check_select(response=response, name=name)
@allure.title("businesses.type.create:typeName为空,返回异常")
@allure.story("创建业务类型:typeName为空,返回异常")
def test_case_05(self):
self.get_base_token()
response = self.businesses_type_create(token=self.token)
self.check_code(response=response, code=100)
@allure.title("businesses.type.create:typeName为空字符串,返回异常")
@allure.story("创建业务类型:typeName为空字符串,返回异常")
def test_case_06(self):
self.get_base_token()
response = self.businesses_type_create(token=self.token, typeName="")
self.check_code(response=response, code=100)
@allure.title("businesses.type.create:重复创建成功")
@allure.story("创建业务类型:重复创建成功")
def test_case_07(self):
self.get_base_token()
name = self.base_typeName + "07"
response = self.businesses_type_create(token=self.token, typeName=name)
self.check_code(response=response, code=0)
self.check_select(response=response, name=name)
response = self.businesses_type_create(token=self.token, typeName=name)
self.check_code(response=response, code=0)
self.check_select(response=response, name=name)
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 = TestBusinessesTypeCreate()
# a.setup_class()
# a.test_case_07()
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-11-25
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.Businesses.Type.businesses_type_create import BusinessesTypeCreate
from WorkApi.APP.Businesses.Type.businesses_type_delete import BusinessesTypeDelete
from WorkData.Argus.members import DataMembers
from WorkData.Argus.businesses_type import DataBusinessesType
import allure
@allure.feature("测试模块:businesses.type.delete")
class TestBusinessesTypeDelete(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_typeName = "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)
DataBusinessesType().delete_like_name(session=session, name=cls.base_typeName)
@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 -- 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("调用接口:businesses.type.create")
def businesses_type_create(self, token=None, typeName=None):
api = BusinessesTypeCreate(_host=self.host)
api.token = token
api.typeName = typeName
api.get_response()
return api.response
@allure.step("调用接口:businesses.type.delete")
def businesses_type_delete(self, token=None, typeIds=None):
api = BusinessesTypeDelete(_host=self.host)
api.token = token
api.typeIds = typeIds
api.get_response()
return api.response
@allure.step("获取token")
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("查询表:businesses_type")
def select_businesses_type(self, _id=None, name=None):
session = self.db_session()
sql = DataBusinessesType().select_all_from_allKeys(session=session, _id=_id, name=name)
return sql
@allure.step("创建测试数据")
def case_create(self, name):
response = self.businesses_type_create(token=self.token, typeName=name)
data = UtilsResponse().get_data(response=response)
self.type_id = data
return self.type_id
@allure.step("校验查询结果")
def check_select(self, type_id):
sql = self.select_businesses_type(_id=type_id)
assert sql == []
@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("businesses.type.delete:token未传")
@allure.story("删除业务类型:token未传")
@allure.severity("blocker")
def test_case_01(self):
self.get_base_token()
response = self.businesses_type_delete()
self.check_code(response=response, code=2001)
self.check_msg(response=response, msg="无token,请重新登录")
@allure.title("businesses.type.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.businesses_type_delete(token=self.token)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("businesses.type.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.businesses_type_delete(token=self.token)
self.check_code(response=response, code=2003)
self.check_msg(response=response, msg="账户已被禁用")
@allure.title("businesses.type.delete:删除一个")
@allure.story("删除业务类型:删除一个")
@allure.severity("blocker")
def test_case_04(self):
self.get_base_token()
name = self.base_typeName + "04"
self.case_create(name=name)
response = self.businesses_type_delete(token=self.token, typeIds=[self.type_id])
self.check_code(response=response, code=0)
self.check_select(type_id=self.type_id)
@allure.title("businesses.type.delete:删除多个")
@allure.story("删除业务类型:删除多个")
def test_case_05(self):
self.get_base_token()
name_1 = self.base_typeName + "051"
name_2 = self.base_typeName + "052"
name_3 = self.base_typeName + "053"
id_1 = self.case_create(name=name_1)
id_2 = self.case_create(name=name_2)
id_3 = self.case_create(name=name_3)
response = self.businesses_type_delete(token=self.token, typeIds=[id_1, id_2, id_3])
self.check_code(response=response, code=0)
self.check_select(type_id=id_1)
self.check_select(type_id=id_2)
self.check_select(type_id=id_3)
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 = TestBusinessesTypeDelete()
# a.setup_class()
# a.test_case_04()
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-11-25
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.Businesses.Type.businesses_type_create import BusinessesTypeCreate
from WorkApi.APP.Businesses.Type.businesses_type_get import BusinessesTypeGet
from WorkData.Argus.members import DataMembers
from WorkData.Argus.businesses_type import DataBusinessesType
import allure
@allure.feature("测试模块:businesses.type.get")
class TestBusinessesTypeGet(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_typeName = "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)
DataBusinessesType().delete_like_name(session=session, name=cls.base_typeName)
@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 -- 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("调用接口:businesses.type.create")
def businesses_type_create(self, token=None, typeName=None):
api = BusinessesTypeCreate(_host=self.host)
api.token = token
api.typeName = typeName
api.get_response()
return api.response
@allure.step("调用接口:businesses.type.get")
def businesses_type_get(self, token=None):
api = BusinessesTypeGet(_host=self.host)
api.token = token
api.get_response()
return api.response
@allure.step("获取token")
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("查询表:businesses_type")
def select_businesses_type(self, _id=None, name=None):
session = self.db_session()
sql = DataBusinessesType().select_all_from_allKeys(session=session, _id=_id, name=name)
return sql
@allure.step("创建测试数据")
def case_create(self, name):
self.businesses_type_create(token=self.token, typeName=name)
@allure.step("校验查询结果")
def check_select(self, response):
data = UtilsResponse().get_data(response=response)
for q, w in enumerate(data):
sql = self.select_businesses_type(_id=w["typeId"])
for x, y in enumerate(sql):
assert y.name == w["typeName"]
assert x == 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("businesses.type.get:token未传")
@allure.story("查询业务类型:token未传")
@allure.severity("blocker")
def test_case_01(self):
self.get_base_token()
response = self.businesses_type_get()
self.check_code(response=response, code=2001)
self.check_msg(response=response, msg="无token,请重新登录")
@allure.title("businesses.type.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.businesses_type_get(token=self.token)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("businesses.type.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.businesses_type_get(token=self.token)
self.check_code(response=response, code=2003)
self.check_msg(response=response, msg="账户已被禁用")
@allure.title("businesses.type.get:无参数调用")
@allure.story("查询业务类型:无参数调用")
@allure.severity("blocker")
def test_case_04(self):
self.get_base_token()
name = self.base_typeName + "04"
self.case_create(name=name)
response = self.businesses_type_get(token=self.token)
self.check_code(response=response, code=0)
self.check_select(response=response)
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 = TestBusinessesTypeGet()
# a.setup_class()
# a.test_case_04()
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-11-25
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.Businesses.Type.businesses_type_create import BusinessesTypeCreate
from WorkApi.APP.Businesses.Type.businesses_type_update import BusinessesTypeUpdate
from WorkData.Argus.members import DataMembers
from WorkData.Argus.businesses_type import DataBusinessesType
import allure
@allure.feature("测试模块:businesses.type.update")
class TestBusinessesTypeUpdate(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_typeName = "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)
DataBusinessesType().delete_like_name(session=session, name=cls.base_typeName)
@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 -- 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("调用接口:businesses.type.create")
def businesses_type_create(self, token=None, typeName=None):
api = BusinessesTypeCreate(_host=self.host)
api.token = token
api.typeName = typeName
api.get_response()
return api.response
@allure.step("调用接口:businesses.type.update")
def businesses_type_update(self, token=None, _id=None, typeName=None):
api = BusinessesTypeUpdate(_host=self.host)
api.token = token
api.id = _id
api.typeName = typeName
api.get_response()
return api.response
@allure.step("获取token")
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("查询表:businesses_type")
def select_businesses_type(self, _id=None, name=None):
session = self.db_session()
sql = DataBusinessesType().select_all_from_allKeys(session=session, _id=_id, name=name)
return sql
@allure.step("创建测试数据")
def case_create(self, name):
response = self.businesses_type_create(token=self.token, typeName=name)
data = UtilsResponse().get_data(response=response)
self.type_id = data
@allure.step("校验查询结果")
def check_select(self, response, name):
data = UtilsResponse().get_data(response=response)
sql = self.select_businesses_type(_id=data)
for x, y in enumerate(sql):
assert y.name == name
assert x == 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("businesses.type.update:token未传")
@allure.story("更新业务类型:token未传")
@allure.severity("blocker")
def test_case_01(self):
self.get_base_token()
response = self.businesses_type_update()
self.check_code(response=response, code=2001)
self.check_msg(response=response, msg="无token,请重新登录")
@allure.title("businesses.type.update: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.businesses_type_update(token=self.token)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("businesses.type.update: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.businesses_type_update(token=self.token)
self.check_code(response=response, code=2003)
self.check_msg(response=response, msg="账户已被禁用")
@allure.title("businesses.type.update:正常修改")
@allure.story("更新业务类型:正常修改")
@allure.severity("blocker")
def test_case_04(self):
self.get_base_token()
name = self.base_typeName + "04"
self.case_create(name=name)
response = self.businesses_type_update(token=self.token, _id=self.type_id, typeName=name + "修改")
self.check_code(response=response, code=0)
self.check_select(response=response, name=name + "修改")
@allure.title("businesses.type.update:id为空,返回正常 无数据修改")
@allure.story("更新业务类型:id为空,返回正常 无数据修改")
def test_case_05(self):
self.get_base_token()
name = self.base_typeName + "05"
self.case_create(name=name)
response = self.businesses_type_update(token=self.token, typeName=name + "修改")
self.check_code(response=response, code=0)
@allure.title("businesses.type.update:typeName为空,返回异常")
@allure.story("更新业务类型:typeName为空,返回异常")
def test_case_06(self):
self.get_base_token()
name = self.base_typeName + "06"
self.case_create(name=name)
response = self.businesses_type_update(token=self.token, _id=self.type_id)
self.check_code(response=response, code=100)
@allure.title("businesses.type.update:typeName为空字符串,返回异常")
@allure.story("更新业务类型:typeName为空字符串,返回异常")
def test_case_07(self):
self.get_base_token()
name = self.base_typeName + "07"
self.case_create(name=name)
response = self.businesses_type_update(token=self.token, _id=self.type_id, typeName="")
self.check_code(response=response, code=100)
@allure.title("businesses.type.update:id字符串,返回异常")
@allure.story("更新业务类型:id字符串,返回异常")
def test_case_08(self):
self.get_base_token()
name = self.base_typeName + "08"
self.case_create(name=name)
response = self.businesses_type_update(token=self.token, _id="Test", typeName=name)
self.check_code(response=response, code=100)
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 = TestBusinessesTypeUpdate()
# a.setup_class()
# a.test_case_08()
......@@ -82,7 +82,7 @@ class TestMembersCreate(object):
api.get_response()
return api.response
@allure.step("创建测试数据")
@allure.step("获取token")
def get_base_token(self):
response = self.api_login(name=self.login_name, password=self.base_password)
self.token = UtilsResponse().get_data(response=response)
......
......@@ -89,7 +89,7 @@ class TestMembersDelete(object):
api.get_response()
return api.response
@allure.step("创建测试数据")
@allure.step("获取token")
def get_base_token(self):
response = self.api_login(name=self.login_name, password=self.base_password)
self.token = UtilsResponse().get_data(response=response)
......
......@@ -92,7 +92,7 @@ class TestMembersGet(object):
api.get_response()
return api.response
@allure.step("创建测试数据")
@allure.step("获取token")
def get_base_token(self):
response = self.api_login(name=self.login_name, password=self.base_password)
self.token = UtilsResponse().get_data(response=response)
......
......@@ -10,8 +10,11 @@ from WorkCase import CaseBase
from WorkUtils.UtilsLog import UtilsLog
from WorkUtils.UtilsResponse import UtilsResponse
from WorkUtils.UtilsDataBase import UtilsDataBase
from WorkApi.APP.Api.api_login import ApiLogin
from WorkApi.APP.Members.Get.members_get_role import MembersGetRole
from WorkData.Argus.members import DataMembers
import allure
......@@ -26,6 +29,10 @@ class TestMembersGetRole(object):
db_pw = env["db_pw"]
db_base = env["db_base"]
login_name = "SS测试用户名"
base_id = 10
base_password = "123456"
@classmethod
def setup_class(cls):
cls.log.debug("开始执行测试套件.......")
......@@ -36,21 +43,61 @@ class TestMembersGetRole(object):
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.get.role")
def members_get_role(self):
def members_get_role(self, token=None):
api = MembersGetRole(_host=self.host)
api.token = token
api.get_response()
return api.response
@allure.step("获取token")
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 -- 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("断言返回结果")
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.step("断言返回结果")
def check_data(self, response):
data = UtilsResponse().get_data(response=response)
......@@ -65,11 +112,42 @@ class TestMembersGetRole(object):
assert y["value"] == "只读角色"
assert y["scope"] == "非配置页面全部只读权限"
@allure.title("members.get.role:无参数调用")
@allure.story("获取用户角色:无参数调用")
@allure.title("members.get.role:token未传")
@allure.story("获取用户角色:token未传")
@allure.severity("blocker")
def test_case_01(self):
self.get_base_token()
response = self.members_get_role()
self.check_code(response=response, code=2001)
self.check_msg(response=response, msg="无token,请重新登录")
@allure.title("members.get.role: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_role(token=self.token)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("members.get.role: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_role(token=self.token)
self.check_code(response=response, code=2003)
self.check_msg(response=response, msg="账户已被禁用")
@allure.title("members.get.role:无参数调用")
@allure.story("获取用户角色:无参数调用")
@allure.severity("blocker")
def test_case_04(self):
self.get_base_token()
response = self.members_get_role(token=self.token)
self.check_code(response=response, code=0)
......
......@@ -99,7 +99,7 @@ class TestMembersUpdateInfo(object):
api.get_response()
return api.response
@allure.step("创建测试数据")
@allure.step("获取token")
def get_base_token(self):
response = self.api_login(name=self.login_name, password=self.base_password)
self.token = UtilsResponse().get_data(response=response)
......
......@@ -90,7 +90,7 @@ class TestMembersUpdateStatus(object):
api.get_response()
return api.response
@allure.step("创建测试数据")
@allure.step("获取token")
def get_base_token(self):
response = self.api_login(name=self.login_name, password=self.base_password)
self.token = UtilsResponse().get_data(response=response)
......
# -*- coding: utf_8 -*-
# 表名: businesses_type
# 作者: 陈磊
# 时间: 2019-11-25
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, VARCHAR, SMALLINT, DATETIME, DECIMAL, BigInteger, FLOAT, NUMERIC, TEXT
from sqlalchemy.orm.exc import MultipleResultsFound, NoResultFound
from sqlalchemy import or_
from WorkUtils.UtilsLog import UtilsLog
from WorkUtils.UtilsDataBase import UtilsDataBase
import time
Base = declarative_base()
class BusinessesType(Base):
"""
业务类型表
"""
__tablename__ = "businesses_type"
id = Column(BigInteger, primary_key=True)
name = Column(VARCHAR(255), comment="名称")
class DataBusinessesType(object):
def __init__(self):
self.log = UtilsLog()
self.log.info(self.__class__)
self.table = BusinessesType
def select_all_from_allKeys(self, session, _id=None, name=None):
"""
:param session: 指针
:param _id:
:param name:
:return: 查询结果
"""
self.log.debug("查询数据库:")
try:
base = UtilsDataBase()
base.add_param(_key="id", value=_id)
base.add_param(_key="name", value=name)
sql_rep = session.query(self.table).filter_by(**base.param).all()
self.log.debug(sql_rep)
session.close()
return sql_rep
except UtilsDataBase().errors as error:
self.log.error("异常:")
self.log.error(error)
session.close()
return error
def delete_like_name(self, session, name):
"""
:param session: 指针
:param name:
:return:
"""
self.log.debug("查询数据库:")
try:
self.log.debug("删除相关测试数据")
session.query(self.table).filter(self.table.name.like(str(name) + "%")).delete(synchronize_session=False)
# session.delete(sql)
session.commit()
session.close()
self.log.debug("删除成功")
return True
except UtilsDataBase().errors as error:
self.log.error("异常:")
self.log.error(error)
session.close()
return error
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