Files
iTop/tests/php-unit-tests/unitary-tests/core/TriggerTest.php
Pierre Goiffon 5d20b76476 N°5893 Fix \TriggerOnObject::LogException for PHPUnit 9
Replaced assertContains by assertStringContainsString
2023-03-10 16:50:57 +01:00

130 lines
3.5 KiB
PHP

<?php
namespace Combodo\iTop\Test\UnitTest\Core;
use Combodo\iTop\Test\UnitTest\ItopDataTestCase;
use ContextTag;
use Exception;
use IssueLog;
use MetaModel;
use Person;
use TriggerOnObjectCreate;
/**
* Class TriggerTest
*
* @package Combodo\iTop\Test\UnitTest\Core
*
* @runTestsInSeparateProcesses
* @preserveGlobalState disabled
* @backupGlobals disabled
*/
class TriggerTest extends ItopDataTestCase
{
const USE_TRANSACTION = false;
protected function setUp(): void
{
parent::setUp();
}
public function testIsContextValid()
{
/** @var TriggerOnObjectCreate $oTrigger */
$oTrigger = MetaModel::NewObject('TriggerOnObjectCreate');
$oTrigger->Set('context', ContextTag::TAG_PORTAL.', '.ContextTag::TAG_CRON);
$this->assertFalse($oTrigger->IsContextValid());
ContextTag::AddContext(ContextTag::TAG_SETUP);
$this->assertFalse($oTrigger->IsContextValid());
ContextTag::AddContext(ContextTag::TAG_CRON);
$this->assertTrue($oTrigger->IsContextValid());
}
public function testEnrichRaisedException_Trigger()
{
$oTrigger = MetaModel::NewObject('TriggerOnObjectCreate');
try {
try {
MetaModel::NewObject('Toto');
}
catch (\Exception $e) {
\utils::EnrichRaisedException($oTrigger, $e);
}
$this->assertTrue(false, "An exception should have been thrown");
}
catch (\CoreException $e1) {
$this->assertEquals('CoreException', get_class($e1));
$this->assertEquals('Unknown class \'Toto\' (<b title="Trigger">TriggerOnObjectCreate</b>::-1 ()<br/>)', $e1->getMessage());
$fullStackTraceAsString = $e1->getFullStackTraceAsString();
$this->assertStringContainsString("MetaModel::NewObject", $fullStackTraceAsString,"new enriched exception should contain root cause method: " . $fullStackTraceAsString);
}
}
public function NoEnrichmentProvider()
{
return [
[null],
[new NonCmdbAbstractObject()],
] ;
}
/**
* @param $oCmdbAbstract
* @dataProvider NoEnrichmentProvider
*/
public function testEnrichRaisedException_NoEnrichment($oCmdbAbstract)
{
try {
try {
MetaModel::NewObject('CoreException');
}
catch (\Exception $e) {
\utils::EnrichRaisedException($oCmdbAbstract, $e);
}
$this->assertTrue(false, "An exception should have been thrown");
}
catch (\Exception $e1) {
$this->assertEquals($e, $e1);
}
}
public function testLogException()
{
$sTestLogPath = APPROOT.'log/TriggerTest__testLogException.log';
IssueLog::Enable($sTestLogPath);
try {
$oPerson1 = MetaModel::GetObject(Person::class, 1, true);
$sExceptionMessage = 'My test exception message';
$oException = new Exception($sExceptionMessage);
/** @var TriggerOnObjectCreate $oTrigger */
$oTrigger = MetaModel::NewObject(TriggerOnObjectCreate::class, [
'description' => 'my trigger description',
]);
$oTrigger->DBWrite();
$oTrigger->LogException($oException, $oPerson1);
$sTestLogFileContent = file_get_contents($sTestLogPath);
$this->assertStringContainsString('A trigger did throw an exception', $sTestLogFileContent);
$this->assertStringContainsString($oPerson1->GetKey(), $sTestLogFileContent);
/** @noinspection GetClassUsageInspection */
$this->assertStringContainsString(get_class($oPerson1), $sTestLogFileContent);
$this->assertStringContainsString($oPerson1->GetRawName(), $sTestLogFileContent);
$this->assertStringContainsString($sExceptionMessage, $sTestLogFileContent);
}
finally {
IssueLog::Enable(APPROOT.'log/error.log');
}
}
}
class NonCmdbAbstractObject{
}