Commit 4f74cc55 by sanshi

登录

parent 59da8d05
......@@ -2,21 +2,28 @@
<dictionary name="Administrator">
<words>
<w>applicationids</w>
<w>businessid</w>
<w>departmentid</w>
<w>dingding</w>
<w>discoveryids</w>
<w>evaltype</w>
<w>eventid</w>
<w>eventids</w>
<w>experienceid</w>
<w>groupid</w>
<w>groupids</w>
<w>hostid</w>
<w>hostids</w>
<w>hostmonitor</w>
<w>hostprototype</w>
<w>itemid</w>
<w>itemids</w>
<w>lastchange</w>
<w>lastcheck</w>
<w>mediatype</w>
<w>mediatypeids</w>
<w>monitorid</w>
<w>networkmonitor</w>
<w>objectid</w>
<w>objectids</w>
<w>preservekeys</w>
......@@ -26,12 +33,14 @@
<w>sanshi</w>
<w>sortfield</w>
<w>sortorder</w>
<w>tablename</w>
<w>templated</w>
<w>templateid</w>
<w>templateids</w>
<w>triggerid</w>
<w>triggerids</w>
<w>triggerprototype</w>
<w>wechat</w>
<w>zabbix</w>
<w>zmops</w>
</words>
......
# -*- coding: utf-8 -*-
# 登录
# 作者: 陈磊
# 时间: 2019-11-20
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class ApiLogin(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 = "/api/login"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.name = None
self.password = None
self.api = UtilsRequest()
def get_response(self):
base = ApiBase()
base.dict_add_key(_key="name", value=self.name)
base.dict_add_key(_key="password", value=self.password)
self.local_json = base._json
self._json = self.local_json
self.response = self.api.post(url=self._url, json=self._json)
# -*- coding: utf-8 -*-
# 更新用户信息
# 作者: 陈磊
# 时间: 2019-11-20
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class MembersUpdateInfo(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 = "/members/update/info"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.name = None
self.position = None
self.role = None
self.password = None
self.phone = None
self.email = None
self.wechatUrl = None
self.dingdingUrl = None
self.remark = None
self.memberId = None
self.api = UtilsRequest()
def get_response(self):
base = ApiBase()
base.dict_add_key(_key="name", value=self.name)
base.dict_add_key(_key="position", value=self.position)
base.dict_add_key(_key="role", value=self.role)
base.dict_add_key(_key="password", value=self.password)
base.dict_add_key(_key="phone", value=self.phone)
base.dict_add_key(_key="email", value=self.email)
base.dict_add_key(_key="wechatUrl", value=self.wechatUrl)
base.dict_add_key(_key="dingdingUrl", value=self.dingdingUrl)
base.dict_add_key(_key="remark", value=self.remark)
base.dict_add_key(_key="memberId", value=self.memberId)
self.local_json = base._json
self._json = self.local_json
self.response = self.api.post(url=self._url, json=self._json)
# -*- coding: utf-8 -*-
# 更新用户状态
# 作者: 陈磊
# 时间: 2019-11-20
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class MembersUpdateStatus(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 = "/members/update/status"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.status = None
self.memberId = None
self.api = UtilsRequest()
def get_response(self):
base = ApiBase()
base.dict_add_key(_key="status", value=self.status)
base.dict_add_key(_key="memberId", value=self.memberId)
self.local_json = base._json
self._json = self.local_json
self.response = self.api.post(url=self._url, json=self._json)
# -*- coding: utf-8 -*-
# 创建用户
# 作者: 陈磊
# 时间: 2019-11-20
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class MembersCreate(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 = "/members/create"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.name = None
self.position = None
self.role = None
self.password = None
self.phone = None
self.email = None
self.wechatUrl = None
self.dingdingUrl = None
self.remark = None
self.api = UtilsRequest()
def get_response(self):
base = ApiBase()
base.dict_add_key(_key="name", value=self.name)
base.dict_add_key(_key="position", value=self.position)
base.dict_add_key(_key="role", value=self.role)
base.dict_add_key(_key="password", value=self.password)
base.dict_add_key(_key="phone", value=self.phone)
base.dict_add_key(_key="email", value=self.email)
base.dict_add_key(_key="wechatUrl", value=self.wechatUrl)
base.dict_add_key(_key="dingdingUrl", value=self.dingdingUrl)
base.dict_add_key(_key="remark", value=self.remark)
self.local_json = base._json
self._json = self.local_json
self.response = self.api.post(url=self._url, json=self._json)
# -*- coding: utf-8 -*-
# 删除用户
# 作者: 陈磊
# 时间: 2019-11-20
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class MembersDelete(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 = "/members/delete"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.memberIds = None
self.api = UtilsRequest()
def get_response(self):
base = ApiBase()
base.dict_add_key(_key="memberIds", value=self.memberIds)
self.local_json = base._json
self._json = self.local_json
self.response = self.api.post(url=self._url, json=self._json)
# -*- coding: utf-8 -*-
# 查询用户
# 作者: 陈磊
# 时间: 2019-11-20
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class MembersGet(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 = "/members/get"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.name = None
self.status = None
self.api = UtilsRequest()
def get_response(self):
base = ApiBase()
base.dict_add_key(_key="name", value=self.name)
base.dict_add_key(_key="status", value=self.status)
self.local_json = base._json
self._json = self.local_json
self.response = self.api.post(url=self._url, json=self._json)
# -*- 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 WorkData.Argus.members import DataMembers
import allure
@allure.feature("测试模块:api.login")
class TestApiLogin(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"]
base_name = "admin"
base_password = "123456"
@classmethod
def setup_class(cls):
cls.log.debug("开始执行测试套件.......")
@classmethod
def teardown_class(cls):
cls.log.debug("结束执行测试套件.......")
def setup_method(self):
self.log.debug("测试用例执行开始...")
def teardown_method(self):
self.log.debug("测试用例执行结束...")
self.log.debug("恢复测试数据...")
self.update_members_del_flag(members_id=1, value=0)
self.update_members_status(members_id=1, 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("连接数据库: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_sortfield(self, response, possible):
result = UtilsResponse().get_result(response=response)
UtilsResponse().check_sort(_list=result, key="groupid", possible=possible)
@allure.step("断言返回结果:校验返回数据的数量")
def check_num(self, response, num):
result = UtilsResponse().get_result(response=response)
assert len(result) == num
@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_status(self, response, status):
_status = UtilsResponse().get_status(response=response)
assert _status == status
@allure.title("api.login:用户密码正确成功登录")
@allure.story("登录:用户密码正确成功登录")
@allure.severity("blocker")
def test_case_01(self):
response = self.api_login(name=self.base_name, password=self.base_password)
self.check_code(response=response, code=0)
@allure.title("api.login:用户不存在无法登录")
@allure.story("登录:用户不存在无法登录")
def test_case_02(self):
response = self.api_login(name="Test", password=self.base_password)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("api.login:密码不正确无法登录")
@allure.story("登录:密码不正确无法登录")
def test_case_03(self):
response = self.api_login(name=self.base_name, password="Test")
self.check_code(response=response, code=2002)
self.check_msg(response=response, msg="账户不存在或密码错误")
@allure.title("api.login:已删除的用户无法登录")
@allure.story("登录:已删除的用户无法登录")
def test_case_04(self):
self.update_members_del_flag(members_id=1, value=1)
response = self.api_login(name=self.base_name, password=self.base_password)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("api.login:已禁用的用户无法登录")
@allure.story("登录:已禁用的用户无法登录")
def test_case_05(self):
self.update_members_status(members_id=1, value=1)
response = self.api_login(name=self.base_name, password=self.base_password)
self.check_code(response=response, code=2003)
self.check_msg(response=response, msg="账户已被禁用")
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 = TestApiLogin()
# a.setup_class()
# a.test_case_05()
# a.teardown_method()
......@@ -76,7 +76,7 @@ class TestExperienceCreate(object):
_code = UtilsResponse().get_code(response=response)
assert _code == code
@allure.step("连接数据库:argus")
@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
......
......@@ -70,7 +70,7 @@ class TestExperienceGet(object):
_code = UtilsResponse().get_code(response=response)
assert _code == code
@allure.step("连接数据库:argus")
@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
......
......@@ -77,7 +77,7 @@ class TestHostMonitorGet(object):
else:
assert value in y[key]
@allure.step("连接数据库:argus")
@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
......
# -*- 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.Members.members_create import MembersCreate
from WorkData.Argus.members import DataMembers
import allure
# allure.label("")
@allure.feature("测试模块:members.create")
class TestMembersCreate(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"]
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("测试用例执行开始...")
def teardown_method(self):
self.log.debug("测试用例执行结束...")
@allure.step("调用接口:members.create")
def members_create(self, name=None, position=None, role=None, password=None,
phone=None, email=None, wechatUrl=None, dingdingUrl=None, remark=None):
api = MembersCreate(_host=self.host)
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("连接数据库: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 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("校验查询结果")
def check_select(self, members_id, name, position, role, password, phone, email, wechatUrl, dingdingUrl, remark):
sql = self.select_memberss(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.wechatUrl == wechatUrl
assert y.dingdingUrl == dingdingUrl
assert y.remark == remark
@allure.step("断言返回结果:校验排序")
def check_sortfield(self, response, possible):
result = UtilsResponse().get_result(response=response)
UtilsResponse().check_sort(_list=result, key="groupid", possible=possible)
@allure.step("断言返回结果:校验返回数据的数量")
def check_num(self, response, num):
result = UtilsResponse().get_result(response=response)
assert len(result) == num
@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_status(self, response, status):
_status = UtilsResponse().get_status(response=response)
assert _status == status
@allure.title("members.create:创建一个用户")
@allure.story("创建用户:创建一个用户")
@allure.severity("blocker")
def test_case_01(self):
response = self.members_create(name=self.base_name, role=0, password=123456)
self.check_code(response=response, code=0)
members_id = UtilsResponse().get_data(response=response)
# self.check_select(membersid=membersid, description=self.base_description, tags_tag=tags_tag, tags_value=tags_value)
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 = TestMembersCreate()
a.setup_class()
a.test_case_01()
......@@ -79,7 +79,7 @@ class TestNetworkMonitorGet(object):
else:
assert value in y[key]
@allure.step("连接数据库:argus")
@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
......
# -*- coding: utf_8 -*-
# 表名: members
# 作者: 陈磊
# 时间: 2019-11-20
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 Members(Base):
"""
用户表
"""
__tablename__ = "members"
id = Column(BigInteger, primary_key=True)
name = Column(VARCHAR(50), comment="用户名")
password = Column(VARCHAR(255), comment="密码")
head_image = Column(VARCHAR(255), comment="头像")
position = Column(VARCHAR(100), comment="职位")
role = Column(Integer, comment="角色")
phone = Column(VARCHAR(20), comment="电话")
email = Column(VARCHAR(50), comment="邮箱")
create_time = Column(BigInteger, comment="创建时间")
login_time = Column(BigInteger, comment="登录时间")
status = Column(Integer, comment="(0:启用;1:禁用)")
remark = Column(VARCHAR(255), comment="备注")
wechat_url = Column(VARCHAR(255), comment="微信访问接口")
dingding_url = Column(BigInteger, comment="钉钉访问接口")
del_flag = Column(Integer, comment="(0:存在;1:删除)")
class DataMembers(object):
def __init__(self):
self.log = UtilsLog()
self.log.info(self.__class__)
self.table = Members
def select_all_from_allKeys(self, session, _id=None, name=None, role=None, status=None, del_flag=None):
"""
:param session: 指针
:param _id:
:param name:
:param role:
:param status:
:param del_flag:
:return: 查询结果
"""
self.log.debug("查询数据库:")
try:
base = UtilsDataBase()
base.add_param(_key="id", value=_id)
base.add_param(_key="name", value=name)
base.add_param(_key="role", value=role)
base.add_param(_key="status", value=status)
base.add_param(_key="del_flag", value=del_flag)
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
def update_del_flag(self, session, _id, value):
"""
:param session: 指针
:param _id:
:param value:
:return:
"""
self.log.debug("查询数据库:")
try:
self.log.debug("更新相关测试数据")
sql_rep = session.query(self.table).filter_by(id=_id).one()
sql_rep.del_flag = value
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
def update_status(self, session, _id, value):
"""
:param session: 指针
:param _id:
:param value:
:return:
"""
self.log.debug("查询数据库:")
try:
self.log.debug("更新相关测试数据")
sql_rep = session.query(self.table).filter_by(id=_id).one()
sql_rep.status = value
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