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.
157 lines
4.0 KiB
157 lines
4.0 KiB
<?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 'vendor/autoload.php';
|
|
|
|
require_once dirname(__FILE__).'/CTest.php';
|
|
|
|
/**
|
|
* Base class for Zabbix API tests.
|
|
*/
|
|
class CAPITest extends CTest {
|
|
|
|
/**
|
|
* Check API response.
|
|
*
|
|
* @param array $response response to be checked
|
|
* @param mixed $error expected error:
|
|
*
|
|
* Possible $error types:
|
|
* null/false - there should not be an error
|
|
* array - exact match
|
|
* string - error message should match
|
|
* int - error code should match
|
|
*/
|
|
public function checkResult($response, $error = null) {
|
|
// Check response data.
|
|
if ($error === null || $error === false) {
|
|
$this->assertArrayHasKey('result', $response, json_encode($response, JSON_PRETTY_PRINT));
|
|
$this->assertArrayNotHasKey('error', $response);
|
|
}
|
|
else {
|
|
$this->assertArrayNotHasKey('result', $response);
|
|
$this->assertArrayHasKey('error', $response);
|
|
|
|
if (is_array($error)) {
|
|
$this->assertSame($error, $response['error']);
|
|
}
|
|
elseif (is_string($error)) {
|
|
$this->assertSame($error, $response['error']['data']);
|
|
}
|
|
elseif (is_numeric($error)) {
|
|
$this->assertSame($error, $response['error']['code']);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Make API call.
|
|
*
|
|
* @param mixed $data String containing request data as json.
|
|
* @param string $sessionid Authorization token.
|
|
*
|
|
* @return array
|
|
*
|
|
* @throws Exception if API call fails.
|
|
*/
|
|
public function callRaw($data, string $sessionid = null) {
|
|
return CAPIHelper::callRaw($data, $sessionid);
|
|
}
|
|
|
|
/**
|
|
* Prepare request for API call and make API call (@see callRaw).
|
|
*
|
|
* @param string $method API method to be called.
|
|
* @param mixed $params API call params.
|
|
* @param mixed $error expected error if any or null/false if successful result is expected.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function call($method, $params, $error = null) {
|
|
if (CAPIHelper::getSessionId() === null) {
|
|
$this->authorize(PHPUNIT_LOGIN_NAME, PHPUNIT_LOGIN_PWD);
|
|
}
|
|
|
|
$response = CAPIHelper::call($method, $params);
|
|
$this->checkResult($response, $error);
|
|
|
|
return $response;
|
|
}
|
|
|
|
/**
|
|
* Enable authorization/session for the following API calls.
|
|
*/
|
|
public static function enableAuthorization() {
|
|
CAPIHelper::setSessionId(null);
|
|
}
|
|
|
|
/**
|
|
* Disable authorization/session for the following API calls.
|
|
*/
|
|
public static function disableAuthorization() {
|
|
CAPIHelper::setSessionId(false);
|
|
}
|
|
|
|
/**
|
|
* Authorize as user.
|
|
*
|
|
* @param string $username
|
|
* @param string $password
|
|
*/
|
|
public function authorize(string $username, string $password) {
|
|
CAPIHelper::authorize($username, $password);
|
|
}
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
protected function onNotSuccessfulTest($t): void {
|
|
if ($t instanceof Exception && CAPIHelper::getDebugInfo()) {
|
|
CExceptionHelper::setMessage($t, $t->getMessage()."\n\nAPI calls:\n".CAPIHelper::getDebugInfoAsString());
|
|
}
|
|
|
|
parent::onNotSuccessfulTest($t);
|
|
}
|
|
|
|
/**
|
|
* Callback executed before every test case.
|
|
*
|
|
* @before
|
|
*/
|
|
public function onBeforeTestCase() {
|
|
global $URL;
|
|
$URL = PHPUNIT_URL.'api_jsonrpc.php';
|
|
CAPIHelper::reset();
|
|
|
|
parent::onBeforeTestCase();
|
|
}
|
|
|
|
/**
|
|
* Callback executed after every test case.
|
|
*
|
|
* @after
|
|
*/
|
|
public function onAfterTestCase() {
|
|
parent::onAfterTestCase();
|
|
|
|
CAPIHelper::clearDebugInfo();
|
|
}
|
|
}
|