Commit 4f6c0922 by sanshi

发现规则

parent beb869df
...@@ -28,12 +28,12 @@ class DRuleDelete(object): ...@@ -28,12 +28,12 @@ class DRuleDelete(object):
self.local_json = {} self.local_json = {}
self.hostids = None self.druleids = None
self.api = UtilsRequest() self.api = UtilsRequest()
def get_response(self): def get_response(self):
base = ApiBase() base = ApiBase()
base.dict_add_key(_key="hostids", value=self.hostids) base.dict_add_key(_key="druleids", value=self.druleids)
self._json = base._json self._json = base._json
self.response = self.api.post(url=self._url, json=self._json) self.response = self.api.post(url=self._url, json=self._json)
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-12-06
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.API.DRule.drule_create import DRuleCreate
from WorkData.Zabbix.drules import DataDrules
from WorkData.Zabbix.dchecks import DataDchecks
import allure
@allure.feature("测试模块:drule.create")
class TestDRuleCreate(object):
log = UtilsLog()
env = CaseBase().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自动化测试发现规则"
base_iprange = "192.168.0.1-254"
base_delay = "1h"
@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)
DataDrules().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("调用接口:drule.create")
def drule_create(self, name=None, iprange=None, delay=None, nextcheck=None,
proxy_hostid=None, status=None, dchecks=None, dchecks_type=None, dchecks_name=None, dchecks_key_=None,
dchecks_snmp_community=None, dchecks_ports=None,
dchecks_host_source=None, dchecks_name_source=None):
api = DRuleCreate(_host=self.host)
api.iprange = iprange
api.name = name
api.delay = delay
api.nextcheck = nextcheck
api.proxy_hostid = proxy_hostid
api.status = status
api.dchecks = dchecks
api.dchecks_type = dchecks_type
api.dchecks_name = dchecks_name
api.dchecks_key_ = dchecks_key_
api.dchecks_snmp_community = dchecks_snmp_community
api.dchecks_ports = dchecks_ports
api.dchecks_host_source = dchecks_host_source
api.dchecks_name_source = dchecks_name_source
api.get_response()
return api.response
@allure.step("连接数据库:zabbix")
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("查询表:drules")
def select_drules(self, druleid=None, name=None, iprange=None):
session = self.db_session()
sql = DataDrules().select_all_from_allKeys(session=session, druleid=druleid, name=name, iprange=iprange)
return sql
@allure.step("查询表:dchecks")
def select_dchecks(self, druleid=None, dcheckid=None):
session = self.db_session()
sql = DataDchecks().select_all_from_allKeys(session=session, druleid=druleid, dcheckid=dcheckid)
return sql
@allure.step("校验查询结果")
def check_select(self, response, dchecks_type, dchecks_key_, dchecks_snmp_community,
dchecks_ports, dchecks_host_source, dchecks_name_source):
result = UtilsResponse().get_result(response=response)
self.druleid = result["druleids"][0]
sql = self.select_drules(druleid=self.druleid)
for x, y in enumerate(sql):
assert y.name == self.name
assert y.iprange == self.base_iprange
assert y.delay == self.base_delay
assert x == 0
sql = self.select_dchecks(druleid=self.druleid)
for x, y in enumerate(sql):
assert y.type == dchecks_type
assert y.key_ == dchecks_key_
assert y.snmp_community == dchecks_snmp_community
assert int(y.ports) == dchecks_ports
assert y.host_source == dchecks_host_source
assert y.name_source == dchecks_name_source
assert y.snmpv3_securitylevel == 0
assert y.snmpv3_authprotocol == 0
assert y.snmpv3_privprotocol == 0
assert x == 0
@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_status(response=response)
assert _msg == msg
@allure.title("drule.create:icmp类型")
@allure.story("创建发现规则:icmp类型")
@allure.severity("blocker")
def test_case_01(self):
self.name = self.base_name + "01"
response = self.drule_create(name=self.name, iprange=self.base_iprange, delay=self.base_delay,
dchecks_type=[12], dchecks_ports=[0], dchecks_host_source=[1], dchecks_name_source=[0])
self.check_code(response=response, code=0)
self.check_select(response=response, dchecks_type=12, dchecks_key_="", dchecks_snmp_community="",
dchecks_ports=0, dchecks_host_source=1, dchecks_name_source=0)
@allure.title("drule.create:agent类型")
@allure.story("创建发现规则:agent类型")
@allure.severity("blocker")
def test_case_02(self):
self.name = self.base_name + "02"
response = self.drule_create(name=self.name, iprange=self.base_iprange, delay=self.base_delay,
dchecks_type=[9], dchecks_ports=[10050], dchecks_host_source=[1], dchecks_name_source=[0],
dchecks_key_=["system.uname"])
self.check_code(response=response, code=0)
self.check_select(response=response, dchecks_type=9, dchecks_key_="system.uname", dchecks_snmp_community="",
dchecks_ports=10050, dchecks_host_source=1, dchecks_name_source=0)
@allure.title("drule.create:snmp类型")
@allure.story("创建发现规则:snmp类型")
@allure.severity("blocker")
def test_case_03(self):
self.name = self.base_name + "03"
response = self.drule_create(name=self.name, iprange=self.base_iprange, delay=self.base_delay,
dchecks_type=[11], dchecks_ports=[161], dchecks_host_source=[1], dchecks_name_source=[0],
dchecks_key_=["1.3.6.1.2.1.25.4.2.1.2"], dchecks_snmp_community=["{$SNMP_COMMUNITY}"])
self.check_code(response=response, code=0)
self.check_select(response=response, dchecks_type=11, dchecks_key_="1.3.6.1.2.1.25.4.2.1.2", dchecks_snmp_community="{$SNMP_COMMUNITY}",
dchecks_ports=161, dchecks_host_source=1, dchecks_name_source=0)
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 = TestDRuleCreate()
# a.setup_class()
# a.test_case_03()
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-12-09
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.API.DRule.drule_create import DRuleCreate
from WorkApi.API.DRule.drule_delete import DRuleDelete
from WorkData.Zabbix.drules import DataDrules
from WorkData.Zabbix.dchecks import DataDchecks
import allure
@allure.feature("测试模块:drule.delete")
class TestDRuleDelete(object):
log = UtilsLog()
env = CaseBase().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自动化测试发现规则"
base_iprange = "192.168.0.1-254"
base_delay = "1h"
@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)
DataDrules().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("调用接口:drule.create")
def drule_create(self, name=None, iprange=None, delay=None, nextcheck=None,
proxy_hostid=None, status=None, dchecks=None, dchecks_type=None, dchecks_name=None, dchecks_key_=None,
dchecks_snmp_community=None, dchecks_ports=None,
dchecks_host_source=None, dchecks_name_source=None):
api = DRuleCreate(_host=self.host)
api.iprange = iprange
api.name = name
api.delay = delay
api.nextcheck = nextcheck
api.proxy_hostid = proxy_hostid
api.status = status
api.dchecks = dchecks
api.dchecks_type = dchecks_type
api.dchecks_name = dchecks_name
api.dchecks_key_ = dchecks_key_
api.dchecks_snmp_community = dchecks_snmp_community
api.dchecks_ports = dchecks_ports
api.dchecks_host_source = dchecks_host_source
api.dchecks_name_source = dchecks_name_source
api.get_response()
return api.response
@allure.step("调用接口:drule.delete")
def drule_delete(self, druleids=None):
api = DRuleDelete(_host=self.host)
api.druleids = druleids
api.get_response()
return api.response
@allure.step("连接数据库:zabbix")
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("查询表:drules")
def select_drules(self, druleid=None, name=None, iprange=None):
session = self.db_session()
sql = DataDrules().select_all_from_allKeys(session=session, druleid=druleid, name=name, iprange=iprange)
return sql
@allure.step("查询表:dchecks")
def select_dchecks(self, druleid=None, dcheckid=None):
session = self.db_session()
sql = DataDchecks().select_all_from_allKeys(session=session, druleid=druleid, dcheckid=dcheckid)
return sql
@allure.step("校验查询结果")
def check_select(self, druleid):
sql = self.select_drules(druleid=druleid)
assert sql == []
@allure.step("断言返回结果:校验排序")
def check_sortfield(self, response, possible):
result = UtilsResponse().get_result(response=response)
UtilsResponse().check_sort(_list=result, key="druleid", 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_status(response=response)
assert _msg == msg
@allure.step("创建测试数据")
def case_create(self, num):
self.name = self.base_name + num
response = self.drule_create(name=self.name, iprange=self.base_iprange, delay=self.base_delay,
dchecks_type=[12], dchecks_ports=[0], dchecks_host_source=[1], dchecks_name_source=[0])
result = UtilsResponse().get_result(response=response)
self.druleid = result["druleids"][0]
return self.druleid
@allure.title("drule.delete:删除一个")
@allure.story("删除发现规则:删除一个")
@allure.severity("blocker")
def test_case_01(self):
druleid_1 = self.case_create(num="01")
response = self.drule_delete(druleids=[druleid_1])
self.check_code(response=response, code=0)
self.check_select(druleid=druleid_1)
@allure.title("drule.delete:删除多个")
@allure.story("删除发现规则:删除多个")
def test_case_02(self):
druleid_1 = self.case_create(num="021")
druleid_2 = self.case_create(num="022")
druleid_3 = self.case_create(num="023")
response = self.drule_delete(druleids=[druleid_1, druleid_2, druleid_3])
self.check_code(response=response, code=0)
self.check_select(druleid=druleid_1)
self.check_select(druleid=druleid_2)
self.check_select(druleid=druleid_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 = TestDRuleDelete()
# a.setup_class()
# a.test_case_02()
# -*- coding: utf-8 -*-
# 测试用例
# 作者: 陈磊
# 时间: 2019-12-06
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.API.DRule.drule_create import DRuleCreate
from WorkApi.API.DRule.drule_update import DRuleUpdate
from WorkData.Zabbix.drules import DataDrules
from WorkData.Zabbix.dchecks import DataDchecks
import allure
@allure.feature("测试模块:drule.update")
class TestDRuleUpdate(object):
log = UtilsLog()
env = CaseBase().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自动化测试发现规则"
base_iprange = "192.168.0.1-254"
base_delay = "1h"
@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)
DataDrules().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("调用接口:drule.create")
def drule_create(self, name=None, iprange=None, delay=None, nextcheck=None,
proxy_hostid=None, status=None, dchecks=None, dchecks_type=None, dchecks_name=None, dchecks_key_=None,
dchecks_snmp_community=None, dchecks_ports=None,
dchecks_host_source=None, dchecks_name_source=None):
api = DRuleCreate(_host=self.host)
api.iprange = iprange
api.name = name
api.delay = delay
api.nextcheck = nextcheck
api.proxy_hostid = proxy_hostid
api.status = status
api.dchecks = dchecks
api.dchecks_type = dchecks_type
api.dchecks_name = dchecks_name
api.dchecks_key_ = dchecks_key_
api.dchecks_snmp_community = dchecks_snmp_community
api.dchecks_ports = dchecks_ports
api.dchecks_host_source = dchecks_host_source
api.dchecks_name_source = dchecks_name_source
api.get_response()
return api.response
@allure.step("调用接口:drule.update")
def drule_update(self, druleid=None, name=None, iprange=None, delay=None, nextcheck=None,
proxy_hostid=None, status=None, dchecks=None, dchecks_type=None, dchecks_name=None, dchecks_key_=None,
dchecks_snmp_community=None, dchecks_ports=None,
dchecks_host_source=None, dchecks_name_source=None):
api = DRuleUpdate(_host=self.host)
api.druleid = druleid
api.iprange = iprange
api.name = name
api.delay = delay
api.nextcheck = nextcheck
api.proxy_hostid = proxy_hostid
api.status = status
api.dchecks = dchecks
api.dchecks_type = dchecks_type
api.dchecks_name = dchecks_name
api.dchecks_key_ = dchecks_key_
api.dchecks_snmp_community = dchecks_snmp_community
api.dchecks_ports = dchecks_ports
api.dchecks_host_source = dchecks_host_source
api.dchecks_name_source = dchecks_name_source
api.get_response()
return api.response
@allure.step("连接数据库:zabbix")
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("查询表:drules")
def select_drules(self, druleid=None, name=None, iprange=None):
session = self.db_session()
sql = DataDrules().select_all_from_allKeys(session=session, druleid=druleid, name=name, iprange=iprange)
return sql
@allure.step("查询表:dchecks")
def select_dchecks(self, druleid=None, dcheckid=None):
session = self.db_session()
sql = DataDchecks().select_all_from_allKeys(session=session, druleid=druleid, dcheckid=dcheckid)
return sql
@allure.step("校验查询结果")
def check_select(self, response, dchecks_type, dchecks_key_, dchecks_snmp_community,
dchecks_ports, dchecks_host_source, dchecks_name_source):
result = UtilsResponse().get_result(response=response)
self.druleid = result["druleids"][0]
sql = self.select_drules(druleid=self.druleid)
for x, y in enumerate(sql):
assert y.name == self.name + "修改"
assert y.iprange == self.base_iprange
assert y.delay == self.base_delay
assert x == 0
sql = self.select_dchecks(druleid=self.druleid)
for x, y in enumerate(sql):
assert y.type == dchecks_type
assert y.key_ == dchecks_key_
assert y.snmp_community == dchecks_snmp_community
assert int(y.ports) == dchecks_ports
assert y.host_source == dchecks_host_source
assert y.name_source == dchecks_name_source
assert y.snmpv3_securitylevel == 0
assert y.snmpv3_authprotocol == 0
assert y.snmpv3_privprotocol == 0
assert x == 0
@allure.step("断言返回结果:校验排序")
def check_sortfield(self, response, possible):
result = UtilsResponse().get_result(response=response)
UtilsResponse().check_sort(_list=result, key="druleid", 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_status(response=response)
assert _msg == msg
@allure.step("创建测试数据")
def case_create(self, num):
self.name = self.base_name + num
response = self.drule_create(name=self.name, iprange=self.base_iprange, delay=self.base_delay,
dchecks_type=[12], dchecks_ports=[0], dchecks_host_source=[1], dchecks_name_source=[0])
result = UtilsResponse().get_result(response=response)
self.druleid = result["druleids"][0]
return self.druleid
@allure.title("drule.update:icmp类型")
@allure.story("更新发现规则:icmp类型")
@allure.severity("blocker")
def test_case_01(self):
self.case_create(num="01")
response = self.drule_update(druleid=self.druleid, name=self.name + "修改", iprange=self.base_iprange, delay=self.base_delay,
dchecks_type=[12], dchecks_ports=[0], dchecks_host_source=[1], dchecks_name_source=[0])
self.check_code(response=response, code=0)
self.check_select(response=response, dchecks_type=12, dchecks_key_="", dchecks_snmp_community="",
dchecks_ports=0, dchecks_host_source=1, dchecks_name_source=0)
@allure.title("drule.update:agent类型")
@allure.story("更新发现规则:agent类型")
@allure.severity("blocker")
def test_case_02(self):
self.case_create(num="02")
response = self.drule_update(druleid=self.druleid, name=self.name + "修改", iprange=self.base_iprange, delay=self.base_delay,
dchecks_type=[9], dchecks_ports=[10050], dchecks_host_source=[1], dchecks_name_source=[0],
dchecks_key_=["system.uname"])
self.check_code(response=response, code=0)
self.check_select(response=response, dchecks_type=9, dchecks_key_="system.uname", dchecks_snmp_community="",
dchecks_ports=10050, dchecks_host_source=1, dchecks_name_source=0)
@allure.title("drule.update:snmp类型")
@allure.story("更新发现规则:snmp类型")
@allure.severity("blocker")
def test_case_03(self):
self.case_create(num="03")
response = self.drule_update(druleid=self.druleid, name=self.name + "修改", iprange=self.base_iprange, delay=self.base_delay,
dchecks_type=[11], dchecks_ports=[161], dchecks_host_source=[1], dchecks_name_source=[0],
dchecks_key_=["1.3.6.1.2.1.25.4.2.1.2"], dchecks_snmp_community=["{$SNMP_COMMUNITY}"])
self.check_code(response=response, code=0)
self.check_select(response=response, dchecks_type=11, dchecks_key_="1.3.6.1.2.1.25.4.2.1.2", dchecks_snmp_community="{$SNMP_COMMUNITY}",
dchecks_ports=161, dchecks_host_source=1, dchecks_name_source=0)
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 = TestDRuleUpdate()
# a.setup_class()
# a.test_case_01()
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