Ordermanager/tests/integration/Actions/actionDeleteOrderTest.php

193 lines
5.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
*/
namespace D3\Ordermanager\tests\integration\Actions;
use D3\ModCfg\Application\Model\d3database;
use D3\ModCfg\Application\Model\Exception\d3_cfg_mod_exception;
use D3\ModCfg\Application\Model\Exception\d3ShopCompatibilityAdapterException;
use D3\Ordermanager\Application\Model\d3ordermanager;
use Doctrine\DBAL\Exception as DBALException;
use Exception;
use OxidEsales\Eshop\Core\Exception\DatabaseConnectionException;
use OxidEsales\Eshop\Core\Exception\DatabaseErrorException;
use OxidEsales\Eshop\Core\Exception\StandardException;
use OxidEsales\Eshop\Core\Model\ListModel;
/**
* @coversNothing
*/
class actionDeleteOrderTest extends d3OrdermanagerActionIntegrationTestCase
{
public $sManagerId = 'managerTestId';
public $aArticleIdList = [
'articleTestIdNo1',
'articleTestIdNo2',
];
public $aOrderIdList = [
'orderTestIdNo1',
'orderTestIdNo2',
];
public $aOrderArticleIdList = [
'orderTestIdNo1Article1',
'orderTestIdNo2Article1',
];
/**
* @throws Exception
*/
public function createTestData()
{
$this->createManager($this->sManagerId);
$this->createArticle(
$this->aArticleIdList[0],
[
'oxtitle' => __CLASS__,
'oxparentid' => null,
'oxstock' => 20,
]
);
$this->createOrder(
$this->aOrderIdList[0],
[
'oxorderdate' => '2018-01-01 00:00:00',
'oxparentid' => '',
'oxbillcompany' => __CLASS__,
],
[
$this->aOrderArticleIdList[0] => [
'oxtitle' => __CLASS__,
'oxartid' => $this->aArticleIdList[0],
],
]
);
$this->createArticle(
$this->aArticleIdList[1],
[
'oxtitle' => __CLASS__,
'oxparentid' => null,
'oxstock' => 20,
]
);
$this->createOrder(
$this->aOrderIdList[1],
[
'oxorderdate' => '2018-01-01 00:00:00',
'oxparentid' => '',
'oxbillcompany' => __CLASS__,
],
[
$this->aOrderArticleIdList[1] => [
'oxtitle' => __CLASS__,
'oxartid' => $this->aArticleIdList[1],
],
]
);
}
/**
* @throws DBALException
*/
public function cleanTestData()
{
$this->deleteManager($this->sManagerId);
$this->deleteOrder($this->aOrderIdList[0]);
$this->deleteOrder($this->aOrderIdList[1]);
$this->deleteArticle($this->aArticleIdList[0]);
$this->deleteArticle($this->aArticleIdList[1]);
}
/**
* @return d3ordermanager
* @throws Exception
*/
public function getConfiguredManager()
{
$oManager = $this->getManagerMock($this->sManagerId);
$oManager->setValue('blActionOrderDelete_status', true);
$oManager->setValue('blItemExecute', true);
return $oManager;
}
/**
* @return ListModel
* @throws Exception
*/
public function getFilledResultList()
{
return $this->getResultList([$this->aOrderIdList[0]]);
}
/**
* @test
* @throws DBALException
* @throws DatabaseConnectionException
* @throws DatabaseErrorException
* @throws StandardException
* @throws d3ShopCompatibilityAdapterException
* @throws d3_cfg_mod_exception
* @throws Exception
*/
public function actionChangeConcernedOrder()
{
$oExecute = $this->getExecuteMock($this->getConfiguredManager());
$oExecute->startJobItemExecution();
$qb = d3database::getInstance()->getQueryBuilder();
$qb->select('count(*)')
->from('oxorder')
->where(
$qb->expr()->in('oxid', implode(', ', array_map(
function ($value) use ($qb) {
return $qb->createNamedParameter($value);
},
[
$this->aOrderIdList[0],
]
)))
);
$this->assertSame(
0,
(int) $qb->execute()->fetchOne()
);
$qb = d3database::getInstance()->getQueryBuilder();
$qb->select('count(*)')
->from('oxorder')
->where(
$qb->expr()->in('oxid', implode(', ', array_map(
function ($value) use ($qb) {
return $qb->createNamedParameter($value);
},
[
$this->aOrderIdList[1],
]
)))
);
$this->assertSame(
1,
(int) $qb->execute()->fetchOne()
);
}
}