Usermanager/tests/integration/Trigger/executeCLICronTest.php

307 lines
9.3 KiB
PHP

<?php
/**
* Copyright (c) D3 Data Development (Inh. Thomas Dartsch)
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*
* https://www.d3data.de
*
* @copyright (C) D3 Data Development (Inh. Thomas Dartsch)
* @author D3 Data Development - Daniel Seifert <info@shopmodule.com>
* @link https://www.oxidmodule.com
*/
declare(strict_types=1);
namespace D3\Usermanager\tests\integration\Trigger;
use D3\ModCfg\Application\Model\Configuration\d3_cfg_mod;
use D3\ModCfg\Application\Model\Exception\d3_cfg_mod_exception;
use D3\ModCfg\Application\Model\Exception\d3ShopCompatibilityAdapterException;
use D3\Usermanager\Application\Model\d3usermanager as Manager;
use D3\Usermanager\Application\Model\Output\d3usermanager_debugoutput;
use D3\Usermanager\Application\Model\Output\d3usermanager_nulloutput;
use D3\Usermanager\publicDir\d3_usermanager_cron;
use D3\Usermanager\tests\integration\d3IntegrationTestCase;
use D3\Usermanager\tests\tools\Intercept;
use Doctrine\DBAL\Exception as DoctrineException;
use Exception;
use OxidEsales\Eshop\Application\Model\User as Item;
use OxidEsales\Eshop\Core\Exception\DatabaseConnectionException;
use OxidEsales\Eshop\Core\Exception\DatabaseErrorException;
use OxidEsales\Eshop\Core\Exception\StandardException;
class executeCLICronTest extends d3IntegrationTestCase
{
public $sManagerId = 'managerTestId';
public $aCountryIdList = [
'testCountryId1Pass',
'testCountryId2Pass',
];
public $aUserIdList = [
'userTestIdNo1',
'userTestIdNo2',
];
public $sCurrentValue = 'current';
public $sExpectedValue = 'expected';
public function setUp(): void
{
parent::setUp();
d3GetOxidDIC()->set(
d3usermanager_debugoutput::class,
oxNew(d3usermanager_nulloutput::class)
);
}
/**
* @throws Exception
*/
public function createTestData()
{
$this->createManager($this->sManagerId);
foreach ($this->aCountryIdList as $sId) {
$this->createBaseModelObject('oxcountry', $sId, [ 'oxtitle' => __METHOD__ ]);
}
$this->createUser(
$this->aUserIdList[0],
[
'oxactive' => 1,
'oxcountryid' => $this->aCountryIdList[0],
'oxfname' => __CLASS__,
'oxlname' => $this->sCurrentValue,
]
);
$this->createUser(
$this->aUserIdList[1],
[
'oxactive' => 1,
'oxcountryid' => $this->aCountryIdList[1],
'oxfname' => __CLASS__,
'oxlname' => $this->sCurrentValue,
]
);
$oManager = $this->getManagerMock($this->sManagerId);
$oManager->assign(
[
'D3_CRONJOBID' => 'testId',
]
);
$this->getConfiguredManager()->save();
}
/**
* @throws DoctrineException
*/
public function cleanTestData()
{
$this->deleteManager($this->sManagerId);
$this->deleteUser($this->aUserIdList[0]);
$this->deleteUser($this->aUserIdList[1]);
foreach ($this->aCountryIdList as $sId) {
$this->deleteBaseModelObject('oxcountry', $sId);
}
}
/**
* @return Manager
* @throws Exception
*/
public function getConfiguredManager()
{
$oManager = $this->getManagerMock($this->sManagerId);
$oManager->assign(
[
'D3_CRONJOBID' => 'testId',
]
);
$oManager->setValue('blActionUserAddFieldValue_status', true);
$oManager->setValue('sActionAddField_field', 'oxlname');
$oManager->setValue('sActionAddField_value', $this->sExpectedValue);
$oManager->setValue('blCheckInvCountry_status', true);
$oManager->setValue('aInvCountryId', [ $this->aCountryIdList[0] ]);
$oManager->setValue('blItemExecute', true);
return $oManager;
}
/**
* @test
* @throws DatabaseConnectionException
* @throws DatabaseErrorException
* @throws StandardException
* @throws d3ShopCompatibilityAdapterException
* @throws d3_cfg_mod_exception
* @throws Exception
*/
public function runCronOk()
{
$set = d3_cfg_mod::get('d3usermanager');
$blCurrentCronStatus = $set->getValue('blCronActive');
$set->setValue('blCronActive', true);
$set->assign([ 'oxactive' => 1 ]);
$set->saveNoLicenseRefresh();
$_GET['shp'] = '1';
$_GET['cjid'] = 'testId';
$this->setCLIArguments(['script', '-q', 'run', '1', 'testId']);
/** @var d3_usermanager_cron $cron */
$cron = oxNew(d3_usermanager_cron::class);
$cron->run();
$set->setValue('blCronActive', $blCurrentCronStatus);
$set->assign([ 'oxactive' => 1 ]);
$set->saveNoLicenseRefresh();
/** @var Item $oItem */
$oItem = d3GetOxidDIC()->get('d3ox.usermanager.'.Item::class);
$oItem->load($this->aUserIdList[0]);
$this->assertSame(
$this->sExpectedValue,
$oItem->getFieldData('oxlname')
);
/** @var Item $oItem */
$oItem = d3GetOxidDIC()->get('d3ox.usermanager.'.Item::class);
$oItem->load($this->aUserIdList[1]);
$this->assertSame(
$this->sCurrentValue,
$oItem->getFieldData('oxlname')
);
}
/**
* @test
* @throws DatabaseConnectionException
* @throws DatabaseErrorException
* @throws StandardException
* @throws d3ShopCompatibilityAdapterException
* @throws d3_cfg_mod_exception
* @throws Exception
*/
public function runCronInactiveModule()
{
$set = d3_cfg_mod::get('d3usermanager');
$blCurrentCronStatus = $set->getValue('blCronActive');
$set->setValue('blCronActive', true);
$set->assign(['oxactive' => 0]);
$set->saveNoLicenseRefresh();
$_GET['shp'] = '1';
$_GET['cjid'] = 'testId';
$this->setCLIArguments(['script', 'run', '1', 'testId']);
stream_filter_register("intercept", Intercept::class);
stream_filter_append(STDERR, "intercept"); // for warning messages and above
//stream_filter_append(STDOUT, "intercept"); // for messages below warning level
/** @var d3_usermanager_cron $cron */
$cron = oxNew(d3_usermanager_cron::class);
$cron->run();
$this->assertMatchesRegularExpression(
'@.*(D3_USERMANAGER_EXC_CRON_MODULEDISABLED|Kundenmanagermodul ist deaktiviert).*@',
Intercept::$cache
);
$set->setValue('blCronActive', $blCurrentCronStatus);
$set->assign(['oxactive' => 1]);
$set->saveNoLicenseRefresh();
/** @var Item $oItem */
$oItem = d3GetOxidDIC()->get('d3ox.usermanager.'.Item::class);
$oItem->load($this->aUserIdList[0]);
$this->assertSame(
$this->sCurrentValue,
$oItem->getFieldData('oxlname')
);
/** @var Item $oItem */
$oItem = d3GetOxidDIC()->get('d3ox.usermanager.'.Item::class);
$oItem->load($this->aUserIdList[1]);
$this->assertSame(
$this->sCurrentValue,
$oItem->getFieldData('oxlname')
);
}
/**
* @test
* @throws DatabaseConnectionException
* @throws DatabaseErrorException
* @throws StandardException
* @throws d3ShopCompatibilityAdapterException
* @throws d3_cfg_mod_exception
* @throws Exception
*/
public function runDisabledCron()
{
$set = d3_cfg_mod::get('d3usermanager');
$blCurrentCronStatus = $set->getValue('blCronActive');
$set->setValue('blCronActive', false);
$set->assign(['oxactive' => 1]);
$set->saveNoLicenseRefresh();
$this->setCLIArguments(['script', 'run', '1', 'testId']);
stream_filter_register("intercept", Intercept::class);
stream_filter_append(STDERR, "intercept"); // for warning messages and above
//stream_filter_append(STDOUT, "intercept"); // for messages below warning level
/** @var d3_usermanager_cron $cron */
$cron = oxNew(d3_usermanager_cron::class);
$cron->run();
$this->assertMatchesRegularExpression(
'@.*(D3_USERMANAGER_EXC_CRON_UNAVAILABLE|Cronjob Aufruf ist deaktiviert).*@',
Intercept::$cache
);
$set->setValue('blCronActive', $blCurrentCronStatus);
$set->assign(['oxactive' => 1]);
$set->saveNoLicenseRefresh();
/** @var Item $oItem */
$oItem = d3GetOxidDIC()->get('d3ox.usermanager.'.Item::class);
$oItem->load($this->aUserIdList[0]);
$this->assertSame(
$this->sCurrentValue,
$oItem->getFieldData('oxlname')
);
/** @var Item $oItem */
$oItem = d3GetOxidDIC()->get('d3ox.usermanager.'.Item::class);
$oItem->load($this->aUserIdList[1]);
$this->assertSame(
$this->sCurrentValue,
$oItem->getFieldData('oxlname')
);
}
/**
* @param array $arguments
*/
public function setCLIArguments($arguments)
{
global $argv;
$argv = $_SERVER['argv'] = $GLOBALS['HTTP_SERVER_VARS']['argv'] = $arguments;
}
}