Commit c440e804 by sanshi

设备类型

parent 4ff684f3
......@@ -26,6 +26,8 @@
<w>hostmacro</w>
<w>hostmonitor</w>
<w>hostprototype</w>
<w>hosttype</w>
<w>hosttypeids</w>
<w>hstgrp</w>
<w>interfaceid</w>
<w>interfaceids</w>
......@@ -65,6 +67,7 @@
<w>serviceids</w>
<w>snmpv</w>
<w>sortfield</w>
<w>sortid</w>
<w>sortorder</w>
<w>tablename</w>
<w>templated</w>
......
# -*- coding: utf-8 -*-
# 创建设备类型
# 作者: 陈磊
# 时间: 2019-11-26
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class HostTypeCreate(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 = "/hosttype/create"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.token = None
self.title = None
self.parentId = None
self.templateIds = None
self.interfaces = None
self.description = None
self.sortid = 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="title", value=self.title)
base.dict_add_key(_key="parentId", value=self.parentId)
base.dict_add_key(_key="templateIds", value=self.templateIds)
base.dict_add_key(_key="interfaces", value=self.interfaces)
base.dict_add_key(_key="description", value=self.description)
base.dict_add_key(_key="sortid", value=self.sortid)
self._json = base._json
self.response = self.api.post(url=self._url, headers=self._headers, json=self._json)
# -*- coding: utf-8 -*-
# 删除设备类型
# 作者: 陈磊
# 时间: 2019-11-26
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class HostTypeDelete(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 = "/hosttype/delete"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.token = None
self.hosttypeids = 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="hosttypeids", value=self.hosttypeids)
self._json = base._json
self.response = self.api.post(url=self._url, headers=self._headers, json=self._json)
# -*- coding: utf-8 -*-
# 查询设备类型
# 作者: 陈磊
# 时间: 2019-11-26
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class HostTypeGet(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 = "/hosttype/get"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.local_json = {}
self.token = None
self.parentId = None
self.title = None
self.description = 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="parentId", value=self.parentId)
base.dict_add_key(_key="title", value=self.title)
base.dict_add_key(_key="description", value=self.description)
self._params = base._json
self.response = self.api.get(url=self._url, headers=self._headers, params=self._params)
# -*- coding: utf-8 -*-
# 更新设备类型
# 作者: 陈磊
# 时间: 2019-11-26
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class HostTypeUpdate(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 = "/hosttype/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.title = None
self.parentId = None
self.templateIds = None
self.interfaces = None
self.description = None
self.sortid = 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="title", value=self.title)
base.dict_add_key(_key="parentId", value=self.parentId)
base.dict_add_key(_key="templateIds", value=self.templateIds)
base.dict_add_key(_key="interfaces", value=self.interfaces)
base.dict_add_key(_key="description", value=self.description)
base.dict_add_key(_key="sortid", value=self.sortid)
self._json = base._json
self.response = self.api.post(url=self._url, headers=self._headers, json=self._json)
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-11-26
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.HostType.hostType_create import HostTypeCreate
from WorkData.Argus.members import DataMembers
from WorkData.Argus.host_types import DataHostTypes
import allure
@allure.feature("测试模块:hosttype.create")
class TestHostTypeCreate(object):
log = UtilsLog()
env = CaseBase().app_environment_host
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_title = "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)
DataHostTypes().delete_like_title(session=session, title=cls.base_title)
@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("调用接口:hosttype.create")
def hostType_create(self, token=None, title=None, parentId=None, templateIds=None, interfaces=None, description=None,
sortid=None):
api = HostTypeCreate(_host=self.host)
api.token = token
api.title = title
api.parentId = parentId
api.templateIds = templateIds
api.interfaces = interfaces
api.description = description
api.sortid = sortid
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("查询表:hosttype")
def select_hosttype(self, _id=None, title=None, parent_id=None):
session = self.db_session()
sql = DataHostTypes().select_all_from_allKeys(session=session, _id=_id, title=title, parent_id=parent_id)
return sql
@allure.step("校验查询结果")
def check_select(self, response, title, parent_id, template_ids, interfaces, description, sortid):
data = UtilsResponse().get_data(response=response)
sql = self.select_hosttype(_id=data)
for x, y in enumerate(sql):
assert y.title == title
assert y.parent_id == parent_id
assert y.template_ids == template_ids
assert y.interfaces == interfaces
assert y.description == description
assert y.sortid == sortid
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("hosttype.create:token未传")
@allure.story("创建设备类型:token未传")
@allure.severity("blocker")
def test_case_01(self):
self.get_base_token()
response = self.hostType_create()
self.check_code(response=response, code=2001)
self.check_msg(response=response, msg="无token,请重新登录")
@allure.title("hosttype.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.hostType_create(token=self.token)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("hosttype.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.hostType_create(token=self.token)
self.check_code(response=response, code=2003)
self.check_msg(response=response, msg="账户已被禁用")
@allure.title("hosttype.create:成功创建")
@allure.story("创建设备类型:成功创建")
@allure.severity("blocker")
def test_case_04(self):
self.get_base_token()
title = self.base_title + "04"
response = self.hostType_create(token=self.token, title=title, parentId=0, templateIds="templateIds",
interfaces="interfaces", description="description", sortid=255)
self.check_code(response=response, code=0)
self.check_select(response=response, title=title, parent_id=0, template_ids="templateIds",
interfaces="interfaces", description="description", sortid=255)
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 = TestHostTypeCreate()
# a.setup_class()
# a.test_case_04()
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-11-26
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.HostType.hostType_create import HostTypeCreate
from WorkApi.APP.HostType.hostType_get import HostTypeGet
from WorkData.Argus.members import DataMembers
from WorkData.Argus.host_types import DataHostTypes
import allure
@allure.feature("测试模块:hosttype.get")
class TestHostTypeGet(object):
log = UtilsLog()
env = CaseBase().app_environment_host
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_title = "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)
DataHostTypes().delete_like_title(session=session, title=cls.base_title)
@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("调用接口:hosttype.create")
def hostType_create(self, token=None, title=None, parentId=None, templateIds=None, interfaces=None, description=None,
sortid=None):
api = HostTypeCreate(_host=self.host)
api.token = token
api.title = title
api.parentId = parentId
api.templateIds = templateIds
api.interfaces = interfaces
api.description = description
api.sortid = sortid
api.get_response()
return api.response
@allure.step("调用接口:hosttype.get")
def hostType_get(self, token=None, title=None, parentId=None, description=None):
api = HostTypeGet(_host=self.host)
api.token = token
api.parentId = parentId
api.title = title
api.description = description
api.get_response()
return api.response
@allure.step("创建测试数据")
def case_create(self, num, parentId):
title = self.base_title + num
response = self.hostType_create(token=self.token, title=title, parentId=parentId)
self.host_type_id = UtilsResponse().get_data(response=response)
return self.host_type_id
@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("查询表:hosttype")
def select_hosttype(self, _id=None, title=None, parent_id=None):
session = self.db_session()
sql = DataHostTypes().select_all_from_allKeys(session=session, _id=_id, title=title, parent_id=parent_id)
return sql
@allure.step("校验查询结果")
def check_select(self, response, title, parent_id, template_ids, interfaces, description, sortid):
data = UtilsResponse().get_data(response=response)
sql = self.select_hosttype(_id=data)
for x, y in enumerate(sql):
assert y.title == title
assert y.parent_id == parent_id
assert y.template_ids == template_ids
assert y.interfaces == interfaces
assert y.description == description
assert y.sortid == sortid
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("hosttype.create:token未传")
@allure.story("创建业务:token未传")
@allure.severity("blocker")
def test_case_01(self):
self.get_base_token()
response = self.hostType_get()
self.check_code(response=response, code=2001)
self.check_msg(response=response, msg="无token,请重新登录")
@allure.title("hosttype.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.hostType_get(token=self.token)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("hosttype.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.hostType_get(token=self.token)
self.check_code(response=response, code=2003)
self.check_msg(response=response, msg="账户已被禁用")
@allure.title("hosttype.create:成功创建")
@allure.story("创建业务:成功创建")
@allure.severity("blocker")
def test_case_04(self):
self.get_base_token()
self.case_create(num="04", parentId=0)
response = self.hostType_get()
self.check_code(response=response, code=0)
# self.check_select(response=response, title=title, parent_id=0, template_ids="templateIds",
# interfaces="interfaces", description="description", sortid=255)
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 = TestHostTypeGet()
a.setup_class()
a.test_case_04()
......@@ -30,3 +30,12 @@ class CaseBase:
"db_pw": "123456",
"db_base": "argus"
}
self.app_environment_host = {
"host": "http://172.16.3.78:3334",
"db_url": "172.16.2.155",
"db_port": 3306,
"db_user": "root",
"db_pw": "123456",
"db_base": "argus"
}
# -*- coding: utf_8 -*-
# 表名: businesses
# 作者: 陈磊
# 时间: 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 HostTypes(Base):
"""
设备类型
"""
__tablename__ = "host_types"
id = Column(BigInteger, primary_key=True)
title = Column(VARCHAR(255), comment="标题")
parent_id = Column(BigInteger, comment="父级ID")
template_ids = Column(VARCHAR(255), comment="模板ID集合")
interfaces = Column(VARCHAR(255), comment="取数方式集合")
description = Column(VARCHAR(255), comment="描述")
sortid = Column(Integer, comment="排序")
create_time = Column(BigInteger, comment="创建时间")
class DataHostTypes(object):
def __init__(self):
self.log = UtilsLog()
self.log.info(self.__class__)
self.table = HostTypes
def select_all_from_allKeys(self, session, _id=None, title=None, parent_id=None):
"""
:param session: 指针
:param _id:
:param title:
:param parent_id:
:return: 查询结果
"""
self.log.debug("查询数据库:")
try:
base = UtilsDataBase()
base.add_param(_key="id", value=_id)
base.add_param(_key="title", value=title)
base.add_param(_key="parent_id", value=parent_id)
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_title(self, session, title):
"""
:param session: 指针
:param title:
:return:
"""
self.log.debug("查询数据库:")
try:
self.log.debug("删除相关测试数据")
session.query(self.table).filter(self.table.title.like(str(title) + "%")).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
......@@ -94,7 +94,6 @@ class UtilsRequest:
if params is None:
params = {}
self.log.debug(str(params).replace('\'', '\"'))
self.log.debug("接口请求json:")
try:
response = self.api.get(url=url, headers=headers, params=params, timeout=60, verify=False)
code = response.status_code
......
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