mirror of
https://github.com/Combodo/iTop.git
synced 2026-05-19 07:12:26 +02:00
Merge remote-tracking branch 'origin/support/2.7' into support/3.0
# Conflicts: # tests/manual-visual-tests/Backoffice/RenderAllUiBlocks.php # tests/php-unit-tests/ItopDataTestCase.php # tests/php-unit-tests/ItopTestCase.php # tests/php-unit-tests/integration-tests/dictionaries-test/fr.dictionary.itop.core.KO.wrong_php # tests/php-unit-tests/integration-tests/dictionaries-test/fr.dictionary.itop.core.OK.php # tests/php-unit-tests/integration-tests/iTopModulesPhpVersionChecklistTest.php # tests/php-unit-tests/integration-tests/iTopXmlVersionChecklistTest.php # tests/php-unit-tests/phpunit.xml.dist # tests/php-unit-tests/unitary-tests/application/SCSSCompilationTest.php # tests/php-unit-tests/unitary-tests/application/Session/SessionTest.php # tests/php-unit-tests/unitary-tests/application/ThemeHandlerTest.php # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/DO_NOT_CHANGE.css-variables.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/DO_NOT_CHANGE.light-grey.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/README.md # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/_included_file3.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/cross_reference1.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/cross_reference2.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/feature1/_feature1.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/included_file1.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/included_scss/included_file2.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/included_scss/included_file4.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/multi_imports.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/shortcut.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/shortcut2.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/simple_import.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/simple_import2.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/typography.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/css/ui-lightness/DO_NOT_CHANGE.jqueryui.scss # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/css/ui-lightness/images/ui-bg_diagonals-thick_18_b81900_40x40.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/css/ui-lightness/images/ui-bg_diagonals-thick_20_666666_40x40.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/css/ui-lightness/images/ui-icons_1c94c4_256x240.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/css/ui-lightness/images/ui-icons_222222_256x240.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/css/ui-lightness/images/ui-icons_E87C1E_256x240.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/css/ui-lightness/images/ui-icons_F26522_256x240.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/css/ui-lightness/images/ui-icons_ffd27a_256x240.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/css/ui-lightness/images/ui-icons_ffffff_256x240.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/ac-background.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/actions_right.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/bg.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/breadcrumb-separator.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/calendar.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/delete.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/desc.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/error.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/eye-closed-555.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/eye-closed-fff.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/eye-open-555.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/eye-open-fff.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/full-screen.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/green-header.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/green-square.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/indicator.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/info-mini.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/minus.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/ok.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/orange-header.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/plus.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/red-header.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/truncated.png # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/tv-collapsable-last.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/tv-collapsable.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/tv-expandable-last.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/tv-expandable.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/tv-item-last.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/testimages/images/tv-item.gif # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/themes/basque-red/main.css # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/themes/basque-red/main_imagemodified.css # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/themes/basque-red/main_importmodified.css # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/themes/basque-red/main_stylesheet.css # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/themes/basque-red/main_testcompilethemes.css # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/themes/basque-red/main_varchanged.css # tests/php-unit-tests/unitary-tests/application/theme-handler/expected/themes/basque-red/theme-parameters.json # tests/php-unit-tests/unitary-tests/application/theme-handler/getimages/expected-getimages.json # tests/php-unit-tests/unitary-tests/application/theme-handler/getimages/test-getimages.scss # tests/php-unit-tests/unitary-tests/core/ActionEmailTest.php # tests/php-unit-tests/unitary-tests/core/AttributeDefTest.inc.php # tests/php-unit-tests/unitary-tests/core/AttributeURLDefaultPattern.php # tests/php-unit-tests/unitary-tests/core/AttributeURLTest.php # tests/php-unit-tests/unitary-tests/core/BulkChangeTest.inc.php # tests/php-unit-tests/unitary-tests/core/CSVParserTest.php # tests/php-unit-tests/unitary-tests/core/DBObjectTest.php # tests/php-unit-tests/unitary-tests/core/DBSearchAddConditionPointingTo.php # tests/php-unit-tests/unitary-tests/core/ExpressionEvaluateTest.php # tests/php-unit-tests/unitary-tests/core/GetSelectFilterTest.php # tests/php-unit-tests/unitary-tests/core/InlineImageTest.php # tests/php-unit-tests/unitary-tests/core/Log/ExceptionLogTest.php # tests/php-unit-tests/unitary-tests/core/Log/ExceptionLogTest/Exceptions.php # tests/php-unit-tests/unitary-tests/core/Log/LogAPITest.php # tests/php-unit-tests/unitary-tests/core/Log/LogFileNameBuilderTest.php # tests/php-unit-tests/unitary-tests/core/LogAPITest.php # tests/php-unit-tests/unitary-tests/core/LogFileNameBuilderTest.php # tests/php-unit-tests/unitary-tests/core/MetaModelTest.php # tests/php-unit-tests/unitary-tests/core/OQLTest.php # tests/php-unit-tests/unitary-tests/core/UniquenessConstraintTest.php # tests/php-unit-tests/unitary-tests/core/XMLDataLoaderTest.php # tests/php-unit-tests/unitary-tests/core/dictApcuTest.php # tests/php-unit-tests/unitary-tests/core/dictTest.php # tests/php-unit-tests/unitary-tests/core/ormCaseLogTest.php # tests/php-unit-tests/unitary-tests/core/ormPasswordTest.php # tests/php-unit-tests/unitary-tests/core/ormStyleTest.php # tests/php-unit-tests/unitary-tests/setup/MFCompilerTest.php # tests/php-unit-tests/unitary-tests/setup/SubMFCompiler.php # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/1.7_to_1.6.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/1.7_to_1.6.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/1.6_to_1.7_2.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/1.6_to_1.7_2.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/1.7.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/1.7_to_1.6.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/1.7_to_1.6.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/1.7_to_1.6_2.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/1.7_to_1.6_2.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/1.7_to_3.0.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/1.7_to_3.0.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/3.0_to_1.7.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/3.0_to_1.7.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/Bug_4569.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/Convert-samples/Bug_4569.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_deleted_to_deleted.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_deleted_to_deleted.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_deleted_to_in-definition.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_deleted_to_in-definition.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_deleted_to_not-in-definition.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_deleted_to_not-in-definition.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_in-definition_to_deleted.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_in-definition_to_deleted.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_in-definition_to_in-definition.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_in-definition_to_in-definition.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_in-definition_to_not-in-definition.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_in-definition_to_not-in-definition.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_not-in-definition_to_deleted.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_not-in-definition_to_deleted.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_not-in-definition_to_in-definition.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_not-in-definition_to_in-definition.input.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_not-in-definition_to_not-in-definition.expected.xml # tests/php-unit-tests/unitary-tests/setup/iTopDesignFormat/MoveNode-samples/from_not-in-definition_to_not-in-definition.input.xml # tests/php-unit-tests/unitary-tests/setup/ressources/datamodels/datamodel-branding.xml # tests/php-unit-tests/unitary-tests/sources/application/Helper/WebResourcesHelperTest.php # tests/php-unit-tests/unitary-tests/sources/application/status/StatusIncTest.php # tests/php-unit-tests/unitary-tests/sources/application/status/status.php # tests/php-unit-tests/unitary-tests/synchro/DataSynchroTest.php
This commit is contained in:
@@ -0,0 +1,926 @@
|
||||
<?php
|
||||
// Copyright (c) 2010-2021 Combodo SARL
|
||||
//
|
||||
// This file is part of iTop.
|
||||
//
|
||||
// iTop is free software; you can redistribute it and/or modify
|
||||
// it under the terms of the GNU Affero General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
//
|
||||
// iTop 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 Affero General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU Affero General Public License
|
||||
// along with iTop. If not, see <http://www.gnu.org/licenses/>
|
||||
//
|
||||
|
||||
/**
|
||||
* Created by PhpStorm.
|
||||
* User: Eric
|
||||
* Date: 18/12/2017
|
||||
* Time: 13:34
|
||||
*/
|
||||
|
||||
namespace Combodo\iTop\Test\UnitTest\iTopTickets;
|
||||
|
||||
use Combodo\iTop\Test\UnitTest\ItopDataTestCase;
|
||||
use Exception;
|
||||
|
||||
|
||||
/**
|
||||
* @group itopVirtualizationMgmt
|
||||
* @group itopConfigMgmt
|
||||
* @group itopTickets
|
||||
*
|
||||
* @runTestsInSeparateProcesses
|
||||
* @preserveGlobalState disabled
|
||||
* @backupGlobals disabled
|
||||
*/
|
||||
class ItopTicketTest extends ItopDataTestCase
|
||||
{
|
||||
const CREATE_TEST_ORG = true;
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* Given:
|
||||
*
|
||||
* Server1+---->Hypervisor1+---->Person1
|
||||
*
|
||||
* Ticket+---->Server1 (manual)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1,Hypervisor1
|
||||
* |
|
||||
* +====>Person1
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_Basic()
|
||||
{
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1);
|
||||
$oPerson1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oPerson1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$aAwaitedCIs = $this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
// Add the computed CIs
|
||||
$aAwaitedCIs = $aAwaitedCIs + array($oHypervisor1->GetKey() => 'computed');
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket, $aAwaitedCIs);
|
||||
|
||||
// Computed Contacts
|
||||
$aAwaitedContacts = array($oPerson1->GetKey() => array('role_code' => 'computed'));
|
||||
$this->CheckContactList($oTicket, $aAwaitedContacts);
|
||||
$this->assertEquals(2, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* Given:
|
||||
*
|
||||
* Server1+---->Hypervisor1+---->Person1
|
||||
*
|
||||
* Ticket+---->Server1 (manual)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1,Hypervisor1
|
||||
* |
|
||||
* +====>Person1
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_Basic2()
|
||||
{
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1);
|
||||
$oPerson1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oPerson1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(2, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket->Get('contacts_list')->Count());
|
||||
|
||||
// Try removing computed entries
|
||||
$this->RemoveCIFromTicket($oHypervisor1, $oTicket);
|
||||
$this->RemoveContactFromTicket($oPerson1, $oTicket);
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(2, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* Given:
|
||||
*
|
||||
* Server1+---->Hypervisor1+---->Person1
|
||||
*
|
||||
* Server2 Person2
|
||||
*
|
||||
* Ticket+---->Server1 (manual), Server2 (computed)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1,Hypervisor1
|
||||
* |
|
||||
* +====>Person1
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_RemoveUnecessaryEntries()
|
||||
{
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1);
|
||||
$oPerson1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oPerson1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oPerson2 = $this->CreatePerson(2);
|
||||
|
||||
$this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$this->AddCIToTicket($oServer2, $oTicket, 'computed');
|
||||
$this->AddContactToTicket($oPerson2, $oTicket, 'computed');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(2, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a first impact chain then remove the root cause, all the chain should be removed.
|
||||
*
|
||||
* <pre>
|
||||
* Given:
|
||||
*
|
||||
* Server1+---->Hypervisor1+---->Person1
|
||||
*
|
||||
* Ticket+---->Server1 (manual)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1,Hypervisor1
|
||||
* |
|
||||
* +====>Person1
|
||||
*
|
||||
* Then remove Server1
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>
|
||||
* |
|
||||
* +====>
|
||||
*
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_RemoveUnecessaryEntries2()
|
||||
{
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1);
|
||||
$oPerson1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oPerson1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(2, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket->Get('contacts_list')->Count());
|
||||
|
||||
$this->RemoveCIFromTicket($oServer1, $oTicket);
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(0, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(0, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
*
|
||||
* Server2+---->Hypervisor2+---->Person2
|
||||
*
|
||||
* Ticket+---->(empty)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>(empty)
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_NoImpact()
|
||||
{
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oPerson2 = $this->CreatePerson(2);
|
||||
$oHypervisor2 = $this->CreateHypervisor(2, $oServer2);
|
||||
$this->AddContactToCI($oPerson2, $oHypervisor2);
|
||||
$oHypervisor2->DBUpdate();
|
||||
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(0, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(0, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* Server1
|
||||
*
|
||||
* Server2+---->Hypervisor2+---->Person2
|
||||
*
|
||||
* Ticket+---->Server1 (manual)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_NoImpact2()
|
||||
{
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oPerson2 = $this->CreatePerson(2);
|
||||
$oHypervisor2 = $this->CreateHypervisor(2, $oServer2);
|
||||
$this->AddContactToCI($oPerson2, $oHypervisor2);
|
||||
$oHypervisor2->DBUpdate();
|
||||
|
||||
$this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(1, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(0, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* +-->Person1
|
||||
* |
|
||||
* +
|
||||
* Server1+---->Hypervisor1+--+
|
||||
* |
|
||||
* v
|
||||
* Farm (1)
|
||||
* ^
|
||||
* |
|
||||
* Server2+---->Hypervisor2+--+
|
||||
* +
|
||||
* |
|
||||
* +-->Person2
|
||||
*
|
||||
* Ticket+---->Server1 (manual)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1,Hypervisor1
|
||||
* |
|
||||
* +====>Person1
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_Redundancy()
|
||||
{
|
||||
$oFarm = $this->CreateFarm(1);
|
||||
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1, $oFarm);
|
||||
$oContact1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oContact1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oHypervisor2 = $this->CreateHypervisor(2, $oServer2, $oFarm);
|
||||
$oContact2 = $this->CreatePerson(2);
|
||||
$this->AddContactToCI($oContact2, $oHypervisor2);
|
||||
$oHypervisor2->DBUpdate();
|
||||
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(2, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* +-->Person1
|
||||
* |
|
||||
* +
|
||||
* Server1+---->Hypervisor1+--+
|
||||
* |
|
||||
* v
|
||||
* Farm (1)
|
||||
* ^
|
||||
* |
|
||||
* Server2+---->Hypervisor2+--+
|
||||
* +
|
||||
* |
|
||||
* +-->Person2
|
||||
*
|
||||
* Ticket+---->Server1 (manual), Hypervisor2 (manual)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1,Hypervisor1,Farm,Hypervisor2
|
||||
* |
|
||||
* +====>Person1,Person2
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_Redundancy2()
|
||||
{
|
||||
$oFarm = $this->CreateFarm(1);
|
||||
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1, $oFarm);
|
||||
$oContact1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oContact1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oHypervisor2 = $this->CreateHypervisor(2, $oServer2, $oFarm);
|
||||
$oContact2 = $this->CreatePerson(2);
|
||||
$this->AddContactToCI($oContact2, $oHypervisor2);
|
||||
$oHypervisor2->DBUpdate();
|
||||
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$this->AddCIToTicket($oHypervisor2, $oTicket, 'manual');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(4, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(2, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* +-->Person1
|
||||
* |
|
||||
* +
|
||||
* Server1+---->Hypervisor1+--+ +-->VM1
|
||||
* | |
|
||||
* v +
|
||||
* Farm (1)
|
||||
* ^ +
|
||||
* | |
|
||||
* Server2+---->Hypervisor2+--+ +-->VM2
|
||||
* +
|
||||
* |
|
||||
* +-->Person2
|
||||
*
|
||||
* Ticket+---->Server1 (manual), Hypervisor2 (manual)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1,Hypervisor1,Farm,Hypervisor2,VM1,VM2
|
||||
* |
|
||||
* +====>Person1,Person2
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_Redundancy3()
|
||||
{
|
||||
$oFarm = $this->CreateFarm(1);
|
||||
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1, $oFarm);
|
||||
$oContact1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oContact1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oHypervisor2 = $this->CreateHypervisor(2, $oServer2, $oFarm);
|
||||
$oContact2 = $this->CreatePerson(2);
|
||||
$this->AddContactToCI($oContact2, $oHypervisor2);
|
||||
$oHypervisor2->DBUpdate();
|
||||
|
||||
$this->CreateVirtualMachine(1, $oFarm);
|
||||
$this->CreateVirtualMachine(2, $oFarm);
|
||||
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$this->AddCIToTicket($oHypervisor2, $oTicket, 'manual');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(6, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(2, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* +-->Person1
|
||||
* |
|
||||
* +
|
||||
* Server1+---->Hypervisor1+--+ +-->VM1
|
||||
* | |
|
||||
* v +
|
||||
* Farm (1)
|
||||
* ^ +
|
||||
* | |
|
||||
* Server2+---->Hypervisor2+--+ +-->VM2
|
||||
* +
|
||||
* |
|
||||
* +-->Person2
|
||||
*
|
||||
* Ticket+---->Server1 (manual), Server2 (manual), Hypervisor2 (not_impacted)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1,Hypervisor1,Server2,Hypervisor2
|
||||
* |
|
||||
* +====>Person1
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_Exclusion()
|
||||
{
|
||||
$oFarm = $this->CreateFarm(1);
|
||||
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1, $oFarm);
|
||||
$oContact1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oContact1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oHypervisor2 = $this->CreateHypervisor(2, $oServer2, $oFarm);
|
||||
$oContact2 = $this->CreatePerson(2);
|
||||
$this->AddContactToCI($oContact2, $oHypervisor2);
|
||||
$oHypervisor2->DBUpdate();
|
||||
|
||||
$this->CreateVirtualMachine(1, $oFarm);
|
||||
$this->CreateVirtualMachine(2, $oFarm);
|
||||
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$this->AddCIToTicket($oServer2, $oTicket, 'manual');
|
||||
$this->AddCIToTicket($oHypervisor2, $oTicket, 'not_impacted');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(4, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* +-->Person1
|
||||
* |
|
||||
* +
|
||||
* Server1+---->Hypervisor1+--+ +-->VM1
|
||||
* | |
|
||||
* v +
|
||||
* Farm (1)
|
||||
* ^ +
|
||||
* | |
|
||||
* Server2+---->Hypervisor2+--+ +-->VM2
|
||||
* +
|
||||
* |
|
||||
* +-->Person2
|
||||
*
|
||||
* Ticket+---->Server1 (manual), Server2 (manual)
|
||||
* |
|
||||
* +---->Person2 (do_not_notify)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1,Hypervisor1,Server2,Hypervisor2,Farm,VM1,VM2
|
||||
* |
|
||||
* +====>Person1,Person2 (do_not_notify)
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_Exclusion2()
|
||||
{
|
||||
$oFarm = $this->CreateFarm(1);
|
||||
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1, $oFarm);
|
||||
$oContact1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oContact1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oHypervisor2 = $this->CreateHypervisor(2, $oServer2, $oFarm);
|
||||
$oContact2 = $this->CreatePerson(2);
|
||||
$this->AddContactToCI($oContact2, $oHypervisor2);
|
||||
$oHypervisor2->DBUpdate();
|
||||
|
||||
$this->CreateVirtualMachine(1, $oFarm);
|
||||
$this->CreateVirtualMachine(2, $oFarm);
|
||||
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$this->AddCIToTicket($oServer2, $oTicket, 'manual');
|
||||
$this->AddContactToTicket($oContact2, $oTicket, 'do_not_notify');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(7, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(2, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* +-->Person1
|
||||
* |
|
||||
* +
|
||||
* Server1+---->Hypervisor1+--+ +-->VM1
|
||||
* | |
|
||||
* v +
|
||||
* Farm (1)
|
||||
* ^ +
|
||||
* | |
|
||||
* Server2+---->Hypervisor2+--+ +-->VM2
|
||||
* +
|
||||
* |
|
||||
* +-->Person2
|
||||
*
|
||||
* Ticket+---->Server1 (manual), Server2 (manual), Hypervisor2 (not_impacted)
|
||||
* |
|
||||
* +---->Person2 (do_not_notify)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1,Hypervisor1,Server2,Hypervisor2
|
||||
* |
|
||||
* +====>Person1,Person2 (do_not_notify)
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_Exclusion3()
|
||||
{
|
||||
$oFarm = $this->CreateFarm(1);
|
||||
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1, $oFarm);
|
||||
$oContact1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oContact1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oHypervisor2 = $this->CreateHypervisor(2, $oServer2, $oFarm);
|
||||
$oContact2 = $this->CreatePerson(2);
|
||||
$this->AddContactToCI($oContact2, $oHypervisor2);
|
||||
$oHypervisor2->DBUpdate();
|
||||
|
||||
$this->CreateVirtualMachine(1, $oFarm);
|
||||
$this->CreateVirtualMachine(2, $oFarm);
|
||||
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$this->AddCIToTicket($oServer2, $oTicket, 'manual');
|
||||
$this->AddCIToTicket($oHypervisor2, $oTicket, 'not_impacted');
|
||||
$this->AddContactToTicket($oContact2, $oTicket, 'do_not_notify');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(4, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(2, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* +-->Person1
|
||||
* |
|
||||
* +
|
||||
* Server1+---->Hypervisor1+--+ +-->VM1
|
||||
* | |
|
||||
* v +
|
||||
* Farm (1)
|
||||
* ^ +
|
||||
* | |
|
||||
* Server2+---->Hypervisor2+--+ +-->VM2
|
||||
* +
|
||||
* |
|
||||
* +-->Person2
|
||||
*
|
||||
* Ticket+---->Server1 (manual), Hypervisor2 (not_impacted)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket+====>Server1,Hypervisor1, Hypervisor2 (not_impacted)
|
||||
* |
|
||||
* +====>Person1
|
||||
* </pre>
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_Exclusion4()
|
||||
{
|
||||
$oFarm = $this->CreateFarm(1);
|
||||
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1, $oFarm);
|
||||
$oContact1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oContact1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oHypervisor2 = $this->CreateHypervisor(2, $oServer2, $oFarm);
|
||||
$oContact2 = $this->CreatePerson(2);
|
||||
$this->AddContactToCI($oContact2, $oHypervisor2);
|
||||
$oHypervisor2->DBUpdate();
|
||||
|
||||
$this->CreateVirtualMachine(1, $oFarm);
|
||||
$this->CreateVirtualMachine(2, $oFarm);
|
||||
|
||||
$oTicket = $this->CreateTicket(1);
|
||||
$this->AddCIToTicket($oServer1, $oTicket, 'manual');
|
||||
$this->AddCIToTicket($oHypervisor2, $oTicket, 'not_impacted');
|
||||
$oTicket->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket); // reload the links
|
||||
|
||||
$this->CheckFunctionalCIList($oTicket);
|
||||
$this->CheckContactList($oTicket);
|
||||
$this->assertEquals(3, $oTicket->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* +-->Person1
|
||||
* |
|
||||
* +
|
||||
* Server1+---->Hypervisor1+--+ +-->VM1
|
||||
* | |
|
||||
* v +
|
||||
* Farm (1)
|
||||
* ^ +
|
||||
* | |
|
||||
* Server2+---->Hypervisor2+--+ +-->VM2
|
||||
* +
|
||||
* |
|
||||
* +-->Person2
|
||||
*
|
||||
* Ticket1+---->Server1 (manual)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket1+====>Server1,Hypervisor1
|
||||
* |
|
||||
* +====>Person1
|
||||
*
|
||||
* Then:
|
||||
*
|
||||
* Ticket2+---->Server2 (manual)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket2+====>Server2,Hypervisor2,Farm,VM1,VM2
|
||||
* |
|
||||
* +====>Person2
|
||||
* </pre>
|
||||
*
|
||||
* @throws \ArchivedObjectException
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_Redundancy_two_tickets()
|
||||
{
|
||||
$oFarm = $this->CreateFarm(1);
|
||||
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1, $oFarm);
|
||||
$oContact1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oContact1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oHypervisor2 = $this->CreateHypervisor(2, $oServer2, $oFarm);
|
||||
$oContact2 = $this->CreatePerson(2);
|
||||
$this->AddContactToCI($oContact2, $oHypervisor2);
|
||||
$oHypervisor2->DBUpdate();
|
||||
|
||||
$oVM1 = $this->CreateVirtualMachine(1, $oFarm);
|
||||
$oVM2 = $this->CreateVirtualMachine(2, $oFarm);
|
||||
|
||||
// Ticket1+---->Server1 (manual)
|
||||
$oTicket1 = $this->CreateTicket(1);
|
||||
$this->AddCIToTicket($oServer1, $oTicket1, 'manual');
|
||||
$oTicket1->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket1); // reload the links
|
||||
|
||||
// Ticket1+====>Server1,Hypervisor1
|
||||
// |
|
||||
// +====>Person1
|
||||
$this->CheckFunctionalCIList($oTicket1);
|
||||
$this->CheckContactList($oTicket1);
|
||||
$this->assertEquals(2, $oTicket1->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket1->Get('contacts_list')->Count());
|
||||
|
||||
// Ticket2+---->Hypervisor2 (manual)
|
||||
$oTicket2 = $this->CreateTicket(2);
|
||||
$this->AddCIToTicket($oServer2, $oTicket2, 'manual');
|
||||
$oTicket2->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket2); // reload the links
|
||||
|
||||
// Ticket2+====>Farm,Hypervisor2,VM1,VM2,Server2
|
||||
// |
|
||||
// +====>Person2
|
||||
$aWaitedCIList = array(
|
||||
$oFarm->GetKey() => 'computed',
|
||||
$oVM1->GetKey() => 'computed',
|
||||
$oVM2->GetKey() => 'computed',
|
||||
$oHypervisor2->GetKey() => 'computed',
|
||||
$oServer2->GetKey() => 'manual');
|
||||
$this->CheckFunctionalCIList($oTicket2, $aWaitedCIList);
|
||||
$this->CheckContactList($oTicket2);
|
||||
$this->assertEquals(2, $oTicket2->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket2->Get('contacts_list')->Count());
|
||||
|
||||
// The first ticket is not impacted
|
||||
$this->debug("\nCheck that the first ticket has not changed.");
|
||||
$this->ReloadObject($oTicket1); // reload the links
|
||||
|
||||
// Ticket1+====>Server1,Hypervisor1
|
||||
// |
|
||||
// +====>Person1
|
||||
$this->CheckFunctionalCIList($oTicket1);
|
||||
$this->CheckContactList($oTicket1);
|
||||
$this->assertEquals(2, $oTicket1->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket1->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
/**
|
||||
* <pre>
|
||||
* +-->Person1
|
||||
* |
|
||||
* +
|
||||
* Server1+---->Hypervisor1+--+ +-->VM1
|
||||
* | |
|
||||
* v +
|
||||
* Server3+---->Hypervisor3+->Farm (1)
|
||||
* ^ +
|
||||
* | |
|
||||
* Server2+---->Hypervisor2+--+ +-->VM2
|
||||
* +
|
||||
* |
|
||||
* +-->Person2
|
||||
*
|
||||
* Ticket1+---->Server1 (manual), Hypervisor2(manual)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket1+====>Server1,Hypervisor1, Hypervisor2
|
||||
* |
|
||||
* +====>Person1, Person2
|
||||
*
|
||||
* Then:
|
||||
*
|
||||
* Ticket2+---->Server2 (manual), Hypervisor3 (manual)
|
||||
*
|
||||
* Result:
|
||||
*
|
||||
* Ticket2+====>Server2,Hypervisor2,Hypervisor3,Farm,VM1,VM2
|
||||
* |
|
||||
* +====>Person2
|
||||
* </pre>
|
||||
*
|
||||
* @throws \ArchivedObjectException
|
||||
* @throws Exception
|
||||
*/
|
||||
public function testUpdateImpactedItems_Redundancy_two_tickets2()
|
||||
{
|
||||
$oFarm = $this->CreateFarm(1);
|
||||
|
||||
$oServer1 = $this->CreateServer(1);
|
||||
$oHypervisor1 = $this->CreateHypervisor(1, $oServer1, $oFarm);
|
||||
$oContact1 = $this->CreatePerson(1);
|
||||
$this->AddContactToCI($oContact1, $oHypervisor1);
|
||||
$oHypervisor1->DBUpdate();
|
||||
|
||||
$oServer2 = $this->CreateServer(2);
|
||||
$oHypervisor2 = $this->CreateHypervisor(2, $oServer2, $oFarm);
|
||||
$oContact2 = $this->CreatePerson(2);
|
||||
$this->AddContactToCI($oContact2, $oHypervisor2);
|
||||
$oHypervisor2->DBUpdate();
|
||||
|
||||
$oServer3 = $this->CreateServer(3);
|
||||
$oHypervisor3 = $this->CreateHypervisor(3, $oServer3, $oFarm);
|
||||
|
||||
|
||||
$oVM1 = $this->CreateVirtualMachine(1, $oFarm);
|
||||
$oVM2 = $this->CreateVirtualMachine(2, $oFarm);
|
||||
|
||||
// Ticket1+---->Server1 (manual), Hypervisor2(manual)
|
||||
$oTicket1 = $this->CreateTicket(1);
|
||||
$this->AddCIToTicket($oServer1, $oTicket1, 'manual');
|
||||
$this->AddCIToTicket($oHypervisor2, $oTicket1, 'manual');
|
||||
$oTicket1->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket1); // reload the links
|
||||
|
||||
// Ticket1+====>Server1,Hypervisor1,Hypervisor2
|
||||
// |
|
||||
// +====>Person1,Person2
|
||||
$this->CheckFunctionalCIList($oTicket1);
|
||||
$this->CheckContactList($oTicket1);
|
||||
$this->assertEquals(3, $oTicket1->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(2, $oTicket1->Get('contacts_list')->Count());
|
||||
|
||||
// Ticket2+---->Server2 (manual)
|
||||
$oTicket2 = $this->CreateTicket(2);
|
||||
$this->AddCIToTicket($oServer2, $oTicket2, 'manual');
|
||||
$this->AddCIToTicket($oHypervisor3, $oTicket2, 'manual');
|
||||
$oTicket2->DBUpdate(); // trigger the impact update
|
||||
$this->ReloadObject($oTicket2); // reload the links
|
||||
|
||||
// Ticket2+====>Farm,Hypervisor2,VM1,VM2,Server2
|
||||
// |
|
||||
// +====>Person2
|
||||
$aWaitedCIList = array(
|
||||
$oFarm->GetKey() => 'computed',
|
||||
$oVM1->GetKey() => 'computed',
|
||||
$oVM2->GetKey() => 'computed',
|
||||
$oHypervisor2->GetKey() => 'computed',
|
||||
$oHypervisor3->GetKey() => 'manual',
|
||||
$oServer2->GetKey() => 'manual');
|
||||
$this->CheckFunctionalCIList($oTicket2, $aWaitedCIList);
|
||||
$this->CheckContactList($oTicket2);
|
||||
$this->assertEquals(3, $oTicket2->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(1, $oTicket2->Get('contacts_list')->Count());
|
||||
|
||||
// The first ticket is not impacted
|
||||
$this->debug("\nCheck that the first ticket has not changed.");
|
||||
$this->ReloadObject($oTicket1); // reload the links
|
||||
|
||||
// Ticket1+====>Server1,Hypervisor1,Hypervisor2
|
||||
// |
|
||||
// +====>Person1,Person2
|
||||
$this->CheckFunctionalCIList($oTicket1);
|
||||
$this->CheckContactList($oTicket1);
|
||||
$this->assertEquals(3, $oTicket1->Get('functionalcis_list')->Count());
|
||||
$this->assertEquals(2, $oTicket1->Get('contacts_list')->Count());
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user