You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
169 lines
4.9 KiB
169 lines
4.9 KiB
1 year ago
|
<?php
|
||
|
/*
|
||
|
** Zabbix
|
||
|
** Copyright (C) 2001-2023 Zabbix SIA
|
||
|
**
|
||
|
** This program is free software; you can redistribute it and/or modify
|
||
|
** it under the terms of the GNU General Public License as published by
|
||
|
** the Free Software Foundation; either version 2 of the License, or
|
||
|
** (at your option) any later version.
|
||
|
**
|
||
|
** This program is distributed in the hope that it will be useful,
|
||
|
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
** GNU General Public License for more details.
|
||
|
**
|
||
|
** You should have received a copy of the GNU General Public License
|
||
|
** along with this program; if not, write to the Free Software
|
||
|
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
|
**/
|
||
|
|
||
|
require_once dirname(__FILE__).'/../include/CIntegrationTest.php';
|
||
|
|
||
|
/**
|
||
|
* Test suite to check if trigger state is updated properly
|
||
|
* when item state toggles between normal and unsupported
|
||
|
*
|
||
|
* @required-components server
|
||
|
* @backup history
|
||
|
* @hosts test
|
||
|
*/
|
||
|
class testTriggerState extends CIntegrationTest {
|
||
|
|
||
|
private static $hostid;
|
||
|
private static $triggerid;
|
||
|
|
||
|
const TRAPPER_ITEM_NAME = 'trap';
|
||
|
const HOST_NAME = 'test';
|
||
|
|
||
|
/**
|
||
|
* @inheritdoc
|
||
|
*/
|
||
|
public function prepareData() {
|
||
|
// Create host "test"
|
||
|
$response = $this->call('host.create', [
|
||
|
'host' => self::HOST_NAME,
|
||
|
'interfaces' => [
|
||
|
[
|
||
|
'type' => 1,
|
||
|
'main' => 1,
|
||
|
'useip' => 1,
|
||
|
'ip' => '127.0.0.1',
|
||
|
'dns' => '',
|
||
|
'port' => $this->getConfigurationValue(self::COMPONENT_AGENT, 'ListenPort')
|
||
|
]
|
||
|
],
|
||
|
'groups' => [
|
||
|
[
|
||
|
'groupid' => 4
|
||
|
]
|
||
|
]
|
||
|
]);
|
||
|
|
||
|
$this->assertArrayHasKey('hostids', $response['result']);
|
||
|
$this->assertArrayHasKey(0, $response['result']['hostids']);
|
||
|
self::$hostid = $response['result']['hostids'][0];
|
||
|
|
||
|
// Get host interface ids.
|
||
|
$response = $this->call('host.get', [
|
||
|
'output' => ['host'],
|
||
|
'hostids' => [self::$hostid],
|
||
|
'selectInterfaces' => ['interfaceid']
|
||
|
]);
|
||
|
|
||
|
$this->assertArrayHasKey(0, $response['result']);
|
||
|
$this->assertArrayHasKey('interfaces', $response['result'][0]);
|
||
|
$this->assertArrayHasKey(0, $response['result'][0]['interfaces']);
|
||
|
|
||
|
// Create trapper item
|
||
|
$response = $this->call('item.create', [
|
||
|
'hostid' => self::$hostid,
|
||
|
'name' => self::TRAPPER_ITEM_NAME,
|
||
|
'key_' => self::TRAPPER_ITEM_NAME,
|
||
|
'type' => ITEM_TYPE_TRAPPER,
|
||
|
'value_type' => ITEM_VALUE_TYPE_UINT64
|
||
|
]);
|
||
|
$this->assertArrayHasKey('itemids', $response['result']);
|
||
|
$this->assertEquals(1, count($response['result']['itemids']));
|
||
|
|
||
|
// Create trigger
|
||
|
$response = $this->call('trigger.create', [
|
||
|
'description' => 'Trapper received 1',
|
||
|
'expression' => 'last(/'.self::HOST_NAME.'/'.self::TRAPPER_ITEM_NAME.')=1'
|
||
|
]);
|
||
|
$this->assertArrayHasKey('triggerids', $response['result']);
|
||
|
$this->assertEquals(1, count($response['result']['triggerids']));
|
||
|
self::$triggerid = $response['result']['triggerids'][0];
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
private function validateTriggerParams($expected_state, $expected_value) {
|
||
|
$response = $this->call('trigger.get', [
|
||
|
'triggerids' => [self::$triggerid]
|
||
|
]);
|
||
|
|
||
|
$this->assertArrayHasKey(0, $response['result']);
|
||
|
$this->assertEquals($expected_state, $response['result'][0]['state']);
|
||
|
$this->assertEquals($expected_value, $response['result'][0]['value']);
|
||
|
}
|
||
|
|
||
|
private function recoverTrigger() {
|
||
|
$this->sendSenderValue(self::HOST_NAME, self::TRAPPER_ITEM_NAME, 0);
|
||
|
$this->validateTriggerParams(TRIGGER_STATE_NORMAL, TRIGGER_VALUE_FALSE);
|
||
|
}
|
||
|
|
||
|
private function fireTrigger() {
|
||
|
$this->sendSenderValue(self::HOST_NAME, self::TRAPPER_ITEM_NAME, 1);
|
||
|
$this->validateTriggerParams(TRIGGER_STATE_NORMAL, TRIGGER_VALUE_TRUE);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Scenario description:
|
||
|
* 1. trigger state is NORMAL, trigger value is OK
|
||
|
* fire trigger
|
||
|
* expect trigger state to be NORMAL and trigger value to be PROBLEM
|
||
|
*
|
||
|
* 2. send unsupported value type
|
||
|
* expect trigger state to be UNKNOWN and trigger value to be PROBLEM
|
||
|
*
|
||
|
* 3. recover trigger
|
||
|
* expect trigger state to be NORMAL and trigger value to be OK
|
||
|
*
|
||
|
*/
|
||
|
public function testTriggerState_checkScenario1() {
|
||
|
// Reload configuration cache before sending values
|
||
|
$this->reloadConfigurationCache();
|
||
|
|
||
|
// Send first value
|
||
|
$this->recoverTrigger();
|
||
|
|
||
|
$this->fireTrigger();
|
||
|
|
||
|
$this->sendSenderValue(self::HOST_NAME, self::TRAPPER_ITEM_NAME, 'a');
|
||
|
$this->validateTriggerParams(TRIGGER_STATE_UNKNOWN, TRIGGER_VALUE_TRUE);
|
||
|
|
||
|
$this->recoverTrigger();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Scenario description:
|
||
|
* 1. trigger state is NORMAL, trigger value is OK
|
||
|
* send unsupported value type
|
||
|
* expect trigger state to be UNKNOWN and trigger value to be OK
|
||
|
*
|
||
|
* 2. fire trigger
|
||
|
* expect trigger state to be NORMAL and trigger value to be PROBLEM
|
||
|
*
|
||
|
* @depends testTriggerState_checkScenario1
|
||
|
*/
|
||
|
public function testTriggerState_checkScenario2() {
|
||
|
$this->sendSenderValue(self::HOST_NAME, self::TRAPPER_ITEM_NAME, 'a');
|
||
|
$this->validateTriggerParams(TRIGGER_STATE_UNKNOWN, TRIGGER_VALUE_FALSE);
|
||
|
|
||
|
$this->fireTrigger();
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|