mirror of
https://github.com/Combodo/iTop.git
synced 2026-04-23 10:38:45 +02:00
N°3455: test when no json_data is passed
This commit is contained in:
@@ -13,11 +13,16 @@ use Exception;
|
||||
*/
|
||||
class RestTest extends ItopDataTestCase
|
||||
{
|
||||
const CREATE_TEST_ORG = true;
|
||||
const USE_TRANSACTION = true;
|
||||
const USE_TRANSACTION = false;
|
||||
|
||||
const MODE = [ 'JSONDATA_AS_STRING' => 0, 'JSONDATA_AS_FILE' => 1 , 'NO_JSONDATA' => 2 ];
|
||||
|
||||
private $sTmpFile = "";
|
||||
private $bCallApiViaFile = false;
|
||||
/** @var int $iJsonDataMode */
|
||||
private $sJsonDataMode;
|
||||
private $sUrl;
|
||||
private $sLogin;
|
||||
private $sPassword = "Iuytrez9876543ç_è-(";
|
||||
|
||||
/**
|
||||
* @throws Exception
|
||||
@@ -25,26 +30,50 @@ class RestTest extends ItopDataTestCase
|
||||
protected function setUp()
|
||||
{
|
||||
parent::setUp();
|
||||
require_once(APPROOT.'application/startup.inc.php');
|
||||
$this->sLogin = "rest-user-" . date('dmYHis');
|
||||
$this->CreateTestOrganization();
|
||||
|
||||
if (!empty($this->sTmpFile)){
|
||||
unlink($this->sTmpFile);
|
||||
}
|
||||
|
||||
$sConfigFile = \utils::GetConfig()->GetLoadedFile();
|
||||
@chmod($sConfigFile, 0770);
|
||||
$this->sUrl = \MetaModel::GetConfig()->Get('app_root_url');
|
||||
@chmod($sConfigFile, 0444); // Read-only
|
||||
|
||||
$oRestProfile = \MetaModel::GetObjectFromOQL("SELECT URP_Profiles WHERE name = :name", array('name' => 'REST Services User'), true);
|
||||
$oAdminProfile = \MetaModel::GetObjectFromOQL("SELECT URP_Profiles WHERE name = :name", array('name' => 'Administrator'), true);
|
||||
|
||||
if (is_object($oRestProfile) && is_object($oAdminProfile))
|
||||
{
|
||||
$oUser = $this->CreateUser($this->sLogin, $oRestProfile->GetKey(), $this->sPassword);
|
||||
$this->AddProfileToUser($oUser, $oAdminProfile->GetKey());
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider BasicProvider
|
||||
* @param int $iJsonDataMode
|
||||
*/
|
||||
public function testBasic($bCallApiViaFile)
|
||||
public function testCreateApi($iJsonDataMode)
|
||||
{
|
||||
$this->bCallApiViaFile = $bCallApiViaFile;
|
||||
$this->iJsonDataMode = $iJsonDataMode;
|
||||
|
||||
//create ticket
|
||||
$description = date('dmY H:i:s');
|
||||
|
||||
$sOuputJson = $this->CreateTicketViaApi($description);
|
||||
$aJson = json_decode($sOuputJson, true);
|
||||
$this->assertContains("0", "".$aJson['code']);
|
||||
$sUserRequestKey = array_key_first($aJson['objects']);
|
||||
|
||||
if ($this->iJsonDataMode === self::MODE['NO_JSONDATA']){
|
||||
$this->assertContains("3", "".$aJson['code'], $sOuputJson);
|
||||
$this->assertContains("Error: Missing parameter 'json_data'", "".$aJson['message'], $sOuputJson);
|
||||
return;
|
||||
}
|
||||
|
||||
$this->assertContains("0", "".$aJson['code'], $sOuputJson);
|
||||
$sUserRequestKey = $this->array_key_first($aJson['objects']);
|
||||
$this->assertContains('UserRequest::', $sUserRequestKey);
|
||||
$iId = $aJson['objects'][$sUserRequestKey]['key'];
|
||||
$sExpectedJsonOuput=<<<JSON
|
||||
@@ -57,6 +86,51 @@ JSON;
|
||||
JSON;
|
||||
$this->assertEquals($sExpectedJsonOuput, $this->GetTicketViaRest($iId));
|
||||
|
||||
$aCmdbChangeUserInfo = $this->GetCmdbChangeUserInfo($iId);
|
||||
$this->assertEquals(['CMDBChangeOpCreate' => 'test'], $aCmdbChangeUserInfo);
|
||||
|
||||
//delete ticket
|
||||
$this->DeleteTicketFromApi($iId);
|
||||
}
|
||||
|
||||
/**
|
||||
* array_key_first comes with PHP7.3
|
||||
* itop should also work with previous PHP versions
|
||||
*/
|
||||
private function array_key_first($aTab){
|
||||
if (!is_array($aTab) || empty($aTab)){
|
||||
return false;
|
||||
}
|
||||
|
||||
foreach ($aTab as $sKey => $sVal){
|
||||
return $sKey;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider BasicProvider
|
||||
* @param int $iJsonDataMode
|
||||
*/
|
||||
public function testUpdateApi($iJsonDataMode)
|
||||
{
|
||||
$this->iJsonDataMode = $iJsonDataMode;
|
||||
|
||||
//create ticket
|
||||
$description = date('dmY H:i:s');
|
||||
$sOuputJson = $this->CreateTicketViaApi($description);
|
||||
$aJson = json_decode($sOuputJson, true);
|
||||
|
||||
if ($this->iJsonDataMode === self::MODE['NO_JSONDATA']){
|
||||
$this->assertContains("3", "".$aJson['code'], $sOuputJson);
|
||||
$this->assertContains("Error: Missing parameter 'json_data'", "".$aJson['message'], $sOuputJson);
|
||||
return;
|
||||
}
|
||||
|
||||
$this->assertContains("0", "".$aJson['code'], $sOuputJson);
|
||||
$sUserRequestKey = $this->array_key_first($aJson['objects']);
|
||||
$this->assertContains('UserRequest::', $sUserRequestKey);
|
||||
$iId = $aJson['objects'][$sUserRequestKey]['key'];
|
||||
|
||||
//update ticket
|
||||
$description = date('Ymd H:i:s');
|
||||
$sExpectedJsonOuput=<<<JSON
|
||||
@@ -64,6 +138,38 @@ JSON;
|
||||
JSON;
|
||||
$this->assertEquals($sExpectedJsonOuput, $this->UpdateTicketViaApi($iId, $description));
|
||||
|
||||
$aCmdbChangeUserInfo = $this->GetCmdbChangeUserInfo($iId);
|
||||
$this->assertEquals(['CMDBChangeOpCreate' => 'test', 'CMDBChangeOpSetAttributeHTML' => 'test'], $aCmdbChangeUserInfo);
|
||||
|
||||
|
||||
//delete ticket
|
||||
$this->DeleteTicketFromApi($iId);
|
||||
}
|
||||
/**
|
||||
* @dataProvider BasicProvider
|
||||
* @param int $iJsonDataMode
|
||||
*/
|
||||
public function testDeleteApi($iJsonDataMode)
|
||||
{
|
||||
$this->iJsonDataMode = $iJsonDataMode;
|
||||
|
||||
//create ticket
|
||||
$description = date('dmY H:i:s');
|
||||
|
||||
$sOuputJson = $this->CreateTicketViaApi($description);
|
||||
$aJson = json_decode($sOuputJson, true);
|
||||
|
||||
if ($this->iJsonDataMode === self::MODE['NO_JSONDATA']){
|
||||
$this->assertContains("3", "".$aJson['code'], $sOuputJson);
|
||||
$this->assertContains("Error: Missing parameter 'json_data'", "".$aJson['message'], $sOuputJson);
|
||||
return;
|
||||
}
|
||||
|
||||
$this->assertContains("0", "".$aJson['code'], $sOuputJson);
|
||||
$sUserRequestKey = $this->array_key_first($aJson['objects']);
|
||||
$this->assertContains('UserRequest::', $sUserRequestKey);
|
||||
$iId = $aJson['objects'][$sUserRequestKey]['key'];
|
||||
|
||||
//delete ticket
|
||||
$sExpectedJsonOuput=<<<JSON
|
||||
{"objects":{"UserRequest::$iId"
|
||||
@@ -91,11 +197,12 @@ JSON;
|
||||
|
||||
public function BasicProvider(){
|
||||
return [
|
||||
'call rest call' => [ 'bCallApiViaFile' => false],
|
||||
'pass json_data as file' => [ 'bCallApiViaFile' => true]
|
||||
'call rest call' => [ 'sJsonDataMode' => self::MODE['JSONDATA_AS_STRING']],
|
||||
'pass json_data as file' => [ 'sJsonDataMode' => self::MODE['JSONDATA_AS_FILE']],
|
||||
'no json data' => [ 'sJsonDataMode' => self::MODE['NO_JSONDATA']]
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
private function UpdateTicketViaApi($iId, $description){
|
||||
$sJsonUpdateContent = <<<JSON
|
||||
{"operation": "core/update","comment": "test","class": "UserRequest","key":"$iId","output_fields": "description","fields":{"description": "$description"}}
|
||||
@@ -142,21 +249,21 @@ JSON;
|
||||
$ch = curl_init();
|
||||
$aPostFields = [
|
||||
'version' => '1.3',
|
||||
'auth_user' => 'admin',
|
||||
'auth_pwd' => 'admin',
|
||||
'auth_user' => $this->sLogin,
|
||||
'auth_pwd' => $this->sPassword,
|
||||
];
|
||||
|
||||
if ($this->bCallApiViaFile){
|
||||
if ($this->iJsonDataMode === self::MODE['JSONDATA_AS_STRING']){
|
||||
$this->sTmpFile = tempnam(sys_get_temp_dir(), 'jsondata_');
|
||||
file_put_contents($this->sTmpFile, $sJsonDataContent);
|
||||
|
||||
$oCurlFile = curl_file_create($this->sTmpFile);
|
||||
$aPostFields['json_data'] = $oCurlFile;
|
||||
}else{
|
||||
}else if ($this->iJsonDataMode === self::MODE['JSONDATA_AS_FILE']){
|
||||
$aPostFields['json_data'] = $sJsonDataContent;
|
||||
}
|
||||
|
||||
curl_setopt($ch, CURLOPT_URL, "http://localhost/iTop/webservices/rest.php");
|
||||
curl_setopt($ch, CURLOPT_URL, "$this->sUrl/webservices/rest.php");
|
||||
curl_setopt($ch, CURLOPT_POST, 1);// set post data to true
|
||||
curl_setopt($ch, CURLOPT_POSTFIELDS, $aPostFields);
|
||||
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
|
||||
@@ -166,4 +273,34 @@ JSON;
|
||||
return $sJson;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param $iId
|
||||
* Get CMDBChangeOp info to test
|
||||
* @return array
|
||||
*/
|
||||
private function GetCmdbChangeUserInfo($iId){
|
||||
$sJsonGetContent = <<<JSON
|
||||
{
|
||||
"operation": "core/get",
|
||||
"class": "CMDBChangeOp",
|
||||
"key": "SELECT CMDBChangeOp WHERE objclass='UserRequest' AND objkey=$iId",
|
||||
"output_fields": "userinfo"
|
||||
}
|
||||
JSON;
|
||||
|
||||
$aUserInfo = [];
|
||||
$sOutput = $this->CallRestApi($sJsonGetContent);
|
||||
$aJson = json_decode($sOutput, true);
|
||||
if (is_array($aJson) && array_key_exists('objects', $aJson)){
|
||||
$aObjects = $aJson['objects'];
|
||||
if (!empty($aObjects)){
|
||||
foreach ($aObjects as $aObject){
|
||||
$sClass = $aObject['class'];
|
||||
$sUserInfo = $aObject['fields']['userinfo'];
|
||||
$aUserInfo[$sClass] = $sUserInfo;
|
||||
}
|
||||
}
|
||||
}
|
||||
return $aUserInfo;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user