Commit 1c0a8c56 by sanshi

资产ips下拉框

parent b732df2d
# -*- coding: utf-8 -*-
# 查询资产IPS
# 作者: 陈磊
# 时间: 2019-12-04
from WorkUtils.UtilsRequest import UtilsRequest
from WorkUtils.UtilsLog import UtilsLog
from WorkApi.ApiBase import ApiBase, GetBase
class DeviceAssetIps(object):
def __init__(self, _host):
"""
:param _host: 域名
:return:
"""
self.log = UtilsLog()
self.log.info("调用查询资产IPS")
self.log.info(self.__class__)
self._host = _host
self._headers = {}
self._path = "/device/asset/ips"
self._url = self._host + self._path
self._params = {}
self._json = {}
self._data = {}
self.response = ""
self.token = None
self.ipName = 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="ipName", value=self.ipName)
self._params = base._json
self.response = self.api.get(url=self._url, headers=self._headers, params=self._params)
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-12-04
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.Device.device_create import DeviceCreate
from WorkApi.APP.Device.Asset.device_asset_ips import DeviceAssetIps
from WorkData.Argus.members import DataMembers
from WorkData.Argus.hosts import DataHosts
import allure
@allure.feature("测试模块:device.asset.ips")
class TestDeviceAssetIps(object):
log = UtilsLog()
env = CaseBase().app_environment
host = "http://172.16.3.78:3334"
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_type_agent = 126
base_type_snmp = 127
base_ip = "172.16.3.171"
base_dns = "sanshi.zmops.com"
base_port = 999
base_name = "SS测试资产-资产IPS"
@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)
DataHosts().delete_like_host_name(session=session, host_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 -- 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("调用接口:device.create")
def device_create(self, token=None, hostName=None, hostType=None, manageLevel=None, iplist=None, dns=None,
monitorInterface=None, monitorType=None,
parentHost=None, businessIds=None, opsPerson=None, snmpCommunity=None, ipmiAuthtype=None,
ipmiPrivilege=None, ipmiUsername=None, ipmiPassword=None,
factory_id=None, model=None, version=None, serialnumber=None,
description=None, monitorStatus=None):
api = DeviceCreate(_host=self.host)
api.token = token
api.hostName = hostName
api.hostType = hostType
api.manageLevel = manageLevel
api.iplist = iplist
api.dns = dns
api.monitorInterface = monitorInterface
api.monitorType = monitorType
api.parentHost = parentHost
api.businessIds = businessIds
api.opsPerson = opsPerson
api.snmpCommunity = snmpCommunity
api.ipmiAuthtype = ipmiAuthtype
api.ipmiPrivilege = ipmiPrivilege
api.ipmiUsername = ipmiUsername
api.ipmiPassword = ipmiPassword
api.factory_id = factory_id
api.model = model
api.version = version
api.serialnumber = serialnumber
api.description = description
api.monitorStatus = monitorStatus
api.get_response()
return api.response
@allure.step("调用接口:device.asset.ips")
def device_asset_ips(self, token=None, ipName=None):
api = DeviceAssetIps(_host=self.host)
api.token = token
api.ipName = ipName
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("查询表:hosts")
def select_hosts(self, hostid=None, host_name=None, available=None, monitor_status=None):
session = self.db_session()
sql = DataHosts().select_all_from_allKeys(session=session, hostid=hostid, host_name=host_name, available=available, monitor_status=monitor_status)
return sql
@allure.step("创建测试数据")
def case_create(self, num):
self.name = self.base_name + num
response = self.device_create(token=self.token, hostName=self.name, hostType=self.base_type_agent, iplist=self.base_ip, monitorInterface=self.base_port,
monitorType=1, manageLevel=1, parentHost="parentHost", businessIds=1, opsPerson=11, snmpCommunity="snmpCommunity",
ipmiAuthtype=1, ipmiPrivilege=1, ipmiUsername="ipmiUsername", ipmiPassword="ipmiPassword",
factory_id="factory", model="model", version="version", serialnumber="serialnumber", description="description",
monitorStatus=1)
self.device_id = UtilsResponse().get_data(response=response)
@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("device.asset.ips:token未传")
@allure.story("查询资产IPS下拉框:token未传")
@allure.severity("blocker")
def test_case_01(self):
self.get_base_token()
response = self.device_asset_ips()
self.check_code(response=response, code=2001)
self.check_msg(response=response, msg="无token,请重新登录")
@allure.title("device.asset.ips:token的用户已删除")
@allure.story("查询资产IPS下拉框: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.device_asset_ips(token=self.token)
self.check_code(response=response, code=2004)
self.check_msg(response=response, msg="用户不存在")
@allure.title("device.asset.ips:token的用户已禁用")
@allure.story("查询资产IPS下拉框: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.device_asset_ips(token=self.token)
self.check_code(response=response, code=2003)
self.check_msg(response=response, msg="账户已被禁用")
@allure.title("device.asset.ips:无参数调用")
@allure.story("查询资产IPS下拉框:无参数调用")
@allure.severity("blocker")
def test_case_04(self):
self.get_base_token()
self.case_create(num="04")
response = self.device_asset_ips(token=self.token)
self.check_code(response=response, code=0)
@allure.title("device.asset.ips:ipName查询")
@allure.story("查询资产IPS下拉框:ipName查询")
def test_case_05(self):
self.get_base_token()
self.case_create(num="05")
response = self.device_asset_ips(token=self.token, ipName=self.base_ip)
self.check_code(response=response, code=0)
data = UtilsResponse().get_data(response=response)
for x, y in enumerate(data):
assert y["id"] == self.device_id
assert y["name"] == self.base_ip
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 = TestDeviceAssetIps()
# a.setup_class()
# a.test_case_05()
...@@ -88,3 +88,51 @@ class DataAlarmRule(object): ...@@ -88,3 +88,51 @@ class DataAlarmRule(object):
self.log.error(error) self.log.error(error)
session.close() session.close()
return error return error
def insert_one(self, session, alarm_ruleid=None, name=None, triggerid=None, description=None, status=None,
period=None, period_unit=None, severity=None, url=None, manual_close=None, enable_time_default=None,
create_time=None):
"""
:param session: 指针
:param alarm_ruleid:
:param name:
:param triggerid:
:param description:
:param status:
:param period:
:param period_unit:
:param severity:
:param url:
:param manual_close:
:param enable_time_default:
:param create_time:
:return:
"""
self.log.debug("新增表数据:")
try:
base = UtilsDataBase()
base.add_param(_key="alarm_ruleid", value=alarm_ruleid)
base.add_param(_key="name", value=name)
base.add_param(_key="triggerid", value=triggerid)
base.add_param(_key="description", value=description)
base.add_param(_key="status", value=status)
base.add_param(_key="period", value=period)
base.add_param(_key="period_unit", value=period_unit)
base.add_param(_key="severity", value=severity)
base.add_param(_key="url", value=url)
base.add_param(_key="manual_close", value=manual_close)
base.add_param(_key="enable_time_default", value=enable_time_default)
base.add_param(_key="create_time", value=create_time)
sql_rep = self.table(**base.param)
session.add(sql_rep)
session.commit()
alarm_ruleid = sql_rep.alarm_ruleid
self.log.debug("新增的alarm_ruleid:%s" % alarm_ruleid)
session.close()
return alarm_ruleid
except UtilsDataBase().errors as error:
self.log.error("异常:")
self.log.error(error)
session.close()
return error
...@@ -84,3 +84,42 @@ class DataBusinesses(object): ...@@ -84,3 +84,42 @@ class DataBusinesses(object):
self.log.error(error) self.log.error(error)
session.close() session.close()
return error return error
def insert_one(self, session, businessid=None, name=None, description=None, _type=None,
principal_name=None, principal_phone=None, memberid=None, create_time=None):
"""
:param session: 指针
:param businessid:
:param name:
:param description:
:param _type:
:param principal_name:
:param principal_phone:
:param memberid:
:param create_time:
:return:
"""
self.log.debug("新增表数据:")
try:
base = UtilsDataBase()
base.add_param(_key="businessid", value=businessid)
base.add_param(_key="name", value=name)
base.add_param(_key="description", value=description)
base.add_param(_key="type", value=_type)
base.add_param(_key="principal_name", value=principal_name)
base.add_param(_key="principal_phone", value=principal_phone)
base.add_param(_key="memberid", value=memberid)
base.add_param(_key="create_time", value=create_time)
sql_rep = self.table(**base.param)
session.add(sql_rep)
session.commit()
businessid = sql_rep.businessid
self.log.debug("新增的businessid:%s" % businessid)
session.close()
return businessid
except UtilsDataBase().errors as error:
self.log.error("异常:")
self.log.error(error)
session.close()
return error
...@@ -39,7 +39,7 @@ class Hosts(Base): ...@@ -39,7 +39,7 @@ class Hosts(Base):
business_ids = Column(VARCHAR(255), comment="业务id(对应于zabbix系统的分组)") business_ids = Column(VARCHAR(255), comment="业务id(对应于zabbix系统的分组)")
port = Column(VARCHAR(30), comment="服务端口号") port = Column(VARCHAR(30), comment="服务端口号")
ops_person = Column(Integer, comment="运维人员") ops_person = Column(Integer, comment="运维人员")
factory = Column(VARCHAR(255), comment="厂商") factory_id = Column(VARCHAR(255), comment="厂商")
model = Column(VARCHAR(255), comment="型号") model = Column(VARCHAR(255), comment="型号")
version = Column(VARCHAR(50), comment="版本号") version = Column(VARCHAR(50), comment="版本号")
serialnumber = Column(VARCHAR(255), comment="序列号") serialnumber = Column(VARCHAR(255), comment="序列号")
...@@ -109,7 +109,8 @@ class DataHosts(object): ...@@ -109,7 +109,8 @@ class DataHosts(object):
return error return error
def insert_one(self, session, host_name=None, asset_code=None, manage_ip=None, departmentid=None, manage_level=None, def insert_one(self, session, host_name=None, asset_code=None, manage_ip=None, departmentid=None, manage_level=None,
host_type=None, parent_host=None, available=None, monitor_status=None, iplist=None, monitor_interface=None): host_type=None, parent_host=None, available=None, monitor_status=None, iplist=None, monitor_interface=None,
del_flag=None):
""" """
:param session: 指针 :param session: 指针
:param host_name: :param host_name:
...@@ -123,6 +124,7 @@ class DataHosts(object): ...@@ -123,6 +124,7 @@ class DataHosts(object):
:param monitor_status: :param monitor_status:
:param iplist: :param iplist:
:param monitor_interface: :param monitor_interface:
:param del_flag:
:return: :return:
""" """
self.log.debug("新增表数据:") self.log.debug("新增表数据:")
...@@ -139,6 +141,7 @@ class DataHosts(object): ...@@ -139,6 +141,7 @@ class DataHosts(object):
base.add_param(_key="monitor_status", value=monitor_status) base.add_param(_key="monitor_status", value=monitor_status)
base.add_param(_key="iplist", value=iplist) base.add_param(_key="iplist", value=iplist)
base.add_param(_key="monitor_interface", value=monitor_interface) base.add_param(_key="monitor_interface", value=monitor_interface)
base.add_param(_key="del_flag", value=del_flag)
sql_rep = self.table(**base.param) sql_rep = self.table(**base.param)
session.add(sql_rep) session.add(sql_rep)
......
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