123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Framework\DB\Test\Unit;
- use Magento\Framework\DB\Select;
- /**
- * Class AbstractMapperTest
- */
- class AbstractMapperTest extends \PHPUnit\Framework\TestCase
- {
- /**
- * @var \Magento\Framework\Model\ResourceModel\Db\AbstractDb|\PHPUnit_Framework_MockObject_MockObject
- */
- protected $resourceMock;
- /**
- * @var \Magento\Framework\DB\Adapter\AdapterInterface|\PHPUnit_Framework_MockObject_MockObject
- */
- protected $connectionMock;
- /**
- * @var \Magento\Framework\DB\Select|\PHPUnit_Framework_MockObject_MockObject
- */
- protected $selectMock;
- /**
- * @var \Psr\Log\LoggerInterface|\PHPUnit_Framework_MockObject_MockObject
- */
- protected $loggerMock;
- /**
- * @var \Magento\Framework\Data\Collection\Db\FetchStrategyInterface|\PHPUnit_Framework_MockObject_MockObject
- */
- protected $fetchStrategyMock;
- /**
- * @var \Magento\Framework\Data\ObjectFactory|\PHPUnit_Framework_MockObject_MockObject
- */
- protected $objectFactoryMock;
- /**
- * @var \Magento\Framework\DB\MapperFactory|\PHPUnit_Framework_MockObject_MockObject
- */
- protected $mapperFactoryMock;
- /**
- * @var \Magento\Framework\DB\AbstractMapper|\PHPUnit_Framework_MockObject_MockObject
- */
- protected $mapper;
- /**
- * Set up
- *
- * @return void
- */
- protected function setUp()
- {
- $this->resourceMock = $this->getMockForAbstractClass(
- \Magento\Framework\Model\ResourceModel\Db\AbstractDb::class,
- [],
- '',
- false,
- true,
- true,
- []
- );
- $this->connectionMock = $this->getMockForAbstractClass(
- \Magento\Framework\DB\Adapter\AdapterInterface::class,
- [],
- '',
- false,
- true,
- true,
- []
- );
- $this->selectMock = $this->createMock(\Magento\Framework\DB\Select::class);
- $this->loggerMock = $this->createMock(\Psr\Log\LoggerInterface::class);
- $this->fetchStrategyMock = $this->getMockForAbstractClass(
- \Magento\Framework\Data\Collection\Db\FetchStrategyInterface::class,
- [],
- '',
- false,
- true,
- true,
- []
- );
- $this->objectFactoryMock = $this->createMock(\Magento\Framework\Data\ObjectFactory::class);
- $this->mapperFactoryMock = $this->createMock(\Magento\Framework\DB\MapperFactory::class);
- }
- /**
- * Run test map method
- *
- * @param array $mapperMethods
- * @param array $criteriaParts
- * @return void
- *
- * @dataProvider dataProviderMap
- */
- public function testMap(array $mapperMethods, array $criteriaParts)
- {
- /** @var \Magento\Framework\DB\AbstractMapper|\PHPUnit_Framework_MockObject_MockObject $mapper */
- $mapper = $this->getMockForAbstractClass(
- \Magento\Framework\DB\AbstractMapper::class,
- [
- 'logger' => $this->loggerMock,
- 'fetchStrategy' => $this->fetchStrategyMock,
- 'objectFactory' => $this->objectFactoryMock,
- 'mapperFactory' => $this->mapperFactoryMock,
- 'select' => $this->selectMock
- ],
- '',
- true,
- true,
- true,
- $mapperMethods
- );
- $criteriaMock = $this->getMockForAbstractClass(
- \Magento\Framework\Api\CriteriaInterface::class,
- [],
- '',
- false,
- true,
- true,
- ['toArray']
- );
- $criteriaMock->expects($this->once())
- ->method('toArray')
- ->will($this->returnValue($criteriaParts));
- foreach ($mapperMethods as $value => $method) {
- $mapper->expects($this->once())
- ->method($method)
- ->with($value);
- }
- $this->assertEquals($this->selectMock, $mapper->map($criteriaMock));
- }
- public function testMapException()
- {
- $mapperMethods = [
- 'my-test-value1' => 'mapMyMapperMethodOne'
- ];
- $criteriaParts = [
- 'my_mapper_method_one' => 'my-test-value1'
- ];
- /** @var \Magento\Framework\DB\AbstractMapper|\PHPUnit_Framework_MockObject_MockObject $mapper */
- $mapper = $this->getMockForAbstractClass(
- \Magento\Framework\DB\AbstractMapper::class,
- [
- 'logger' => $this->loggerMock,
- 'fetchStrategy' => $this->fetchStrategyMock,
- 'objectFactory' => $this->objectFactoryMock,
- 'mapperFactory' => $this->mapperFactoryMock,
- 'select' => $this->selectMock
- ],
- '',
- true,
- true,
- true,
- $mapperMethods
- );
- $criteriaMock = $this->getMockForAbstractClass(
- \Magento\Framework\Api\CriteriaInterface::class,
- [],
- '',
- false,
- true,
- true,
- ['toArray']
- );
- $criteriaMock->expects($this->once())
- ->method('toArray')
- ->will($this->returnValue($criteriaParts));
- $this->expectException(\InvalidArgumentException::class);
- $mapper->map($criteriaMock);
- }
- /**
- * Run test addExpressionFieldToSelect method
- *
- * @return void
- */
- public function testAddExpressionFieldToSelect()
- {
- $fields = [
- 'key-attribute' => 'value-attribute',
- ];
- /** @var \Magento\Framework\DB\AbstractMapper|\PHPUnit_Framework_MockObject_MockObject $mapper */
- $mapper = $this->getMockForAbstractClass(
- \Magento\Framework\DB\AbstractMapper::class,
- [
- 'logger' => $this->loggerMock,
- 'fetchStrategy' => $this->fetchStrategyMock,
- 'objectFactory' => $this->objectFactoryMock,
- 'mapperFactory' => $this->mapperFactoryMock,
- 'select' => $this->selectMock
- ],
- '',
- true,
- true,
- true,
- []
- );
- $this->selectMock->expects($this->once())
- ->method('columns')
- ->with(['my-alias' => "('sub_total', 'SUM(value-attribute)', 'revenue')"]);
- $mapper->addExpressionFieldToSelect('my-alias', "('sub_total', 'SUM({{key-attribute}})', 'revenue')", $fields);
- }
- /**
- * Run test addExpressionFieldToSelect method
- *
- * @param mixed $field
- * @param mixed $condition
- * @return void
- *
- * @dataProvider dataProviderAddFieldToFilter
- */
- public function testAddFieldToFilter($field, $condition)
- {
- $resultCondition = 'sql-condition-value';
- /** @var \Magento\Framework\DB\AbstractMapper|\PHPUnit_Framework_MockObject_MockObject $mapper */
- $mapper = $this->getMockForAbstractClass(
- \Magento\Framework\DB\AbstractMapper::class,
- [
- 'logger' => $this->loggerMock,
- 'fetchStrategy' => $this->fetchStrategyMock,
- 'objectFactory' => $this->objectFactoryMock,
- 'mapperFactory' => $this->mapperFactoryMock,
- 'select' => $this->selectMock
- ],
- '',
- true,
- true,
- true,
- ['getConnection']
- );
- $connectionMock = $this->getMockForAbstractClass(
- \Magento\Framework\DB\Adapter\AdapterInterface::class,
- [],
- '',
- true,
- true,
- true,
- ['quoteIdentifier', 'prepareSqlCondition']
- );
- $mapper->expects($this->any())
- ->method('getConnection')
- ->will($this->returnValue($connectionMock));
- $connectionMock->expects($this->any())
- ->method('quoteIdentifier')
- ->with('my-field')
- ->will($this->returnValue('quote-field'));
- $connectionMock->expects($this->any())
- ->method('prepareSqlCondition')
- ->with('quote-field', $condition)
- ->will($this->returnValue($resultCondition));
- if (is_array($field)) {
- $resultCondition = '(' . implode(
- ') ' . \Magento\Framework\DB\Select::SQL_OR . ' (',
- array_fill(0, count($field), $resultCondition)
- ) . ')';
- }
- $this->selectMock->expects($this->once())
- ->method('where')
- ->with($resultCondition, null, Select::TYPE_CONDITION);
- $mapper->addFieldToFilter($field, $condition);
- }
- /**
- * Data provider for map method
- *
- * @return array
- */
- public function dataProviderMap()
- {
- return [
- [
- 'mapperMethods' => [
- 'my-test-value1' => 'mapMyMapperMethodOne',
- 'my-test-value2' => 'mapMyMapperMethodTwo',
- ],
- 'criteriaParts' => [
- 'my_mapper_method_one' => ['my-test-value1'],
- 'my_mapper_method_two' => ['my-test-value2'],
- ],
- ]
- ];
- }
- /**
- * Data provider for addFieldToFilter method
- *
- * @return array
- */
- public function dataProviderAddFieldToFilter()
- {
- return [
- [
- 'field' => 'my-field',
- 'condition' => ['condition'],
- ],
- [
- 'field' => ['my-field', 'my-field'],
- 'condition' => null
- ],
- ];
- }
- }
|