-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
TE-7546 Add tests for group by usages
- Loading branch information
1 parent
c4fd526
commit d6d67b4
Showing
4 changed files
with
310 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
246 changes: 246 additions & 0 deletions
246
tests/SprykerTest/Zed/ProductList/Persistence/ProductListRepositoryTest.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,246 @@ | ||
<?php | ||
|
||
/** | ||
* Copyright © 2016-present Spryker Systems GmbH. All rights reserved. | ||
* Use of this software requires acceptance of the Evaluation License Agreement. See LICENSE file. | ||
*/ | ||
|
||
namespace SprykerTest\Zed\ProductList\Persistence; | ||
|
||
use Codeception\Test\Unit; | ||
use Generated\Shared\Transfer\ProductListProductConcreteRelationTransfer; | ||
use Generated\Shared\Transfer\ProductListTransfer; | ||
use Orm\Zed\ProductList\Persistence\Map\SpyProductListProductConcreteTableMap; | ||
use Orm\Zed\ProductList\Persistence\Map\SpyProductListTableMap; | ||
use Orm\Zed\ProductList\Persistence\SpyProductListProductConcreteQuery; | ||
use Spryker\Zed\ProductList\Persistence\ProductListRepository; | ||
|
||
/** | ||
* Auto-generated group annotations | ||
* | ||
* @group SprykerTest | ||
* @group Zed | ||
* @group ProductList | ||
* @group Persistence | ||
* @group Repository | ||
* @group ProductListRepositoryTest | ||
* Add your own group annotations below this line | ||
*/ | ||
class ProductListRepositoryTest extends Unit | ||
{ | ||
/** | ||
* @var \SprykerTest\Zed\ProductList\ProductListPersistenceTester | ||
*/ | ||
protected $tester; | ||
|
||
/** | ||
* @var \Spryker\Zed\ProductList\Persistence\ProductListRepositoryInterface | ||
*/ | ||
protected $productListRepository; | ||
|
||
/** | ||
* @var \Generated\Shared\Transfer\ProductConcreteTransfer | ||
*/ | ||
protected $productConcreteTransfer1; | ||
|
||
/** | ||
* @var \Generated\Shared\Transfer\ProductConcreteTransfer | ||
*/ | ||
protected $productConcreteTransfer2; | ||
|
||
/** | ||
* @var \Generated\Shared\Transfer\ProductListProductConcreteRelationTransfer | ||
*/ | ||
protected $productListProductConcreteRelation; | ||
|
||
/** | ||
* @return void | ||
*/ | ||
protected function setUp(): void | ||
{ | ||
parent::setUp(); | ||
|
||
$this->productListRepository = new ProductListRepository(); | ||
$this->productConcreteTransfer1 = $this->tester->haveProduct(); | ||
$this->productConcreteTransfer2 = $this->tester->haveProduct(); | ||
|
||
$this->productListProductConcreteRelation = (new ProductListProductConcreteRelationTransfer()) | ||
->setProductIds([ | ||
$this->productConcreteTransfer1->getIdProductConcrete(), | ||
$this->productConcreteTransfer2->getIdProductConcrete() | ||
]); | ||
} | ||
|
||
/** | ||
* @return void | ||
*/ | ||
public function testGetProductListIdsByProductIdsReturnsCorrectData(): void | ||
{ | ||
//Assert | ||
$productConcreteIds = [ | ||
$this->productConcreteTransfer1->getIdProductConcrete(), | ||
$this->productConcreteTransfer2->getIdProductConcrete() | ||
]; | ||
$this->tester->haveProductList([ | ||
ProductListTransfer::PRODUCT_LIST_PRODUCT_CONCRETE_RELATION => $this->productListProductConcreteRelation->toArray(), | ||
]); | ||
|
||
//Act | ||
$result = $this->productListRepository->getProductListIdsByProductIds($productConcreteIds); | ||
|
||
//Arrange | ||
$this->assertCount(2, $result); | ||
$resultProductConcreteIds = array_column($result, SpyProductListProductConcreteTableMap::COL_FK_PRODUCT); | ||
$this->assertContains($productConcreteIds[0], $resultProductConcreteIds); | ||
$this->assertContains($productConcreteIds[1], $resultProductConcreteIds); | ||
} | ||
|
||
/** | ||
* @return void | ||
*/ | ||
public function testGetProductConcreteProductListIdsForTypeReturnsCorrectProductListId(): void | ||
{ | ||
//Assert | ||
|
||
$productListTransfer = $this->tester->haveProductList([ | ||
ProductListTransfer::PRODUCT_LIST_PRODUCT_CONCRETE_RELATION => $this->productListProductConcreteRelation->toArray(), | ||
]); | ||
|
||
//Act | ||
$result = $this->productListRepository->getProductConcreteProductListIdsForType( | ||
$this->productConcreteTransfer1->getIdProductConcrete(), | ||
$productListTransfer->getType() | ||
); | ||
|
||
//Arrange | ||
$this->assertCount(1, $result); | ||
$this->assertSame($productListTransfer->getIdProductList(), $result[0]); | ||
} | ||
|
||
/** | ||
* @return void | ||
*/ | ||
public function testGetProductBlacklistIdsByIdProductAbstractReturnsCorrectProductListId(): void | ||
{ | ||
//Assert | ||
$productListTransfer = $this->tester->haveProductList([ | ||
ProductListTransfer::TYPE => SpyProductListTableMap::COL_TYPE_BLACKLIST, | ||
ProductListTransfer::PRODUCT_LIST_PRODUCT_CONCRETE_RELATION => $this->productListProductConcreteRelation->toArray(), | ||
]); | ||
|
||
//Act | ||
$result = $this->productListRepository->getProductBlacklistIdsByIdProductAbstract( | ||
$this->productConcreteTransfer1->getFkProductAbstract() | ||
); | ||
|
||
//Arrange | ||
$this->assertCount(1, $result); | ||
$this->assertSame($productListTransfer->getIdProductList(), $result[0]); | ||
} | ||
|
||
/** | ||
* @return void | ||
*/ | ||
public function testGetAbstractProductWhitelistIdsReturnsCorrectProductListId(): void | ||
{ | ||
//Assert | ||
$productListTransfer = $this->tester->haveProductList([ | ||
ProductListTransfer::TYPE => SpyProductListTableMap::COL_TYPE_WHITELIST, | ||
ProductListTransfer::PRODUCT_LIST_PRODUCT_CONCRETE_RELATION => $this->productListProductConcreteRelation->toArray(), | ||
]); | ||
|
||
//Act | ||
$result = $this->productListRepository->getAbstractProductWhitelistIds( | ||
$this->productConcreteTransfer1->getFkProductAbstract() | ||
); | ||
|
||
//Arrange | ||
$this->assertCount(1, $result); | ||
$this->assertSame($productListTransfer->getIdProductList(), $result[0]); | ||
} | ||
|
||
/** | ||
* @return void | ||
*/ | ||
public function testGetProductListByProductAbstractIdsThroughCategoryReturnsCorrectProductAbstractIds(): void | ||
{ | ||
//Assert | ||
$categoryTransfer = $this->tester->haveCategory(); | ||
$this->tester->assignProductToCategory($categoryTransfer->getIdCategory(), $this->productConcreteTransfer1->getFkProductAbstract()); | ||
$this->tester->assignProductToCategory($categoryTransfer->getIdCategory(), $this->productConcreteTransfer2->getFkProductAbstract()); | ||
|
||
$productListTransfer = $this->tester->haveProductList([ | ||
ProductListTransfer::TYPE => SpyProductListTableMap::COL_TYPE_WHITELIST, | ||
ProductListTransfer::PRODUCT_LIST_PRODUCT_CONCRETE_RELATION => $this->productListProductConcreteRelation->toArray(), | ||
]); | ||
$this->tester->haveProductListCategory($productListTransfer->getIdProductList(), $categoryTransfer->getIdCategory()); | ||
|
||
$productAbstractIds = [ | ||
$this->productConcreteTransfer1->getFkProductAbstract(), | ||
$this->productConcreteTransfer2->getFkProductAbstract(), | ||
]; | ||
|
||
//Act | ||
$result = $this->productListRepository->getProductListByProductAbstractIdsThroughCategory( | ||
$productAbstractIds | ||
); | ||
|
||
//Arrange | ||
$this->assertCount(2, $result); | ||
$resultProductAbstractIds = array_column($result, ProductListRepository::COL_ID_PRODUCT_ABSTRACT); | ||
$this->assertContains($productAbstractIds[0], $resultProductAbstractIds); | ||
$this->assertContains($productAbstractIds[1], $resultProductAbstractIds); | ||
} | ||
|
||
/** | ||
* @return void | ||
*/ | ||
public function testGetProductBlacklistsByProductAbstractIdsReturnsCorrectData(): void | ||
{ | ||
//Assert | ||
$this->tester->haveProductList([ | ||
ProductListTransfer::TYPE => SpyProductListTableMap::COL_TYPE_BLACKLIST, | ||
ProductListTransfer::PRODUCT_LIST_PRODUCT_CONCRETE_RELATION => $this->productListProductConcreteRelation->toArray(), | ||
]); | ||
|
||
$productAbstractIds = [ | ||
$this->productConcreteTransfer1->getFkProductAbstract(), | ||
$this->productConcreteTransfer2->getFkProductAbstract(), | ||
]; | ||
|
||
//Act | ||
$result = $this->productListRepository->getProductBlacklistsByProductAbstractIds($productAbstractIds); | ||
|
||
//Arrange | ||
$this->assertCount(2, $result); | ||
$resultProductAbstractIds = array_column($result, ProductListRepository::COL_ID_PRODUCT_ABSTRACT); | ||
$this->assertContains($productAbstractIds[0], $resultProductAbstractIds); | ||
$this->assertContains($productAbstractIds[1], $resultProductAbstractIds); | ||
} | ||
|
||
/** | ||
* @return void | ||
*/ | ||
public function testGetProductWhitelistsByProductAbstractIdsReturnsCorrectData(): void | ||
{ | ||
//Assert | ||
$this->tester->haveProductList([ | ||
ProductListTransfer::TYPE => SpyProductListTableMap::COL_TYPE_WHITELIST, | ||
ProductListTransfer::PRODUCT_LIST_PRODUCT_CONCRETE_RELATION => $this->productListProductConcreteRelation->toArray(), | ||
]); | ||
|
||
$productAbstractIds = [ | ||
$this->productConcreteTransfer1->getFkProductAbstract(), | ||
$this->productConcreteTransfer2->getFkProductAbstract(), | ||
]; | ||
|
||
//Act | ||
$result = $this->productListRepository->getProductWhiteListsByProductAbstractIds($productAbstractIds); | ||
|
||
//Arrange | ||
$this->assertCount(2, $result); | ||
$resultProductAbstractIds = array_column($result, ProductListRepository::COL_ID_PRODUCT_ABSTRACT); | ||
$this->assertContains($productAbstractIds[0], $resultProductAbstractIds); | ||
$this->assertContains($productAbstractIds[1], $resultProductAbstractIds); | ||
} | ||
} |
48 changes: 48 additions & 0 deletions
48
tests/SprykerTest/Zed/ProductList/_support/ProductListPersistenceTester.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
<?php | ||
namespace SprykerTest\Zed\ProductList; | ||
|
||
use Codeception\Actor; | ||
use Generated\Shared\Transfer\ProductListCategoryRelationTransfer; | ||
use Orm\Zed\ProductList\Persistence\SpyProductListCategoryQuery; | ||
|
||
/** | ||
* Inherited Methods | ||
* @method void wantToTest($text) | ||
* @method void wantTo($text) | ||
* @method void execute($callable) | ||
* @method void expectTo($prediction) | ||
* @method void expect($prediction) | ||
* @method void amGoingTo($argumentation) | ||
* @method void am($role) | ||
* @method void lookForwardTo($achieveValue) | ||
* @method void comment($description) | ||
* @method void pause() | ||
* | ||
* @SuppressWarnings(PHPMD) | ||
*/ | ||
class ProductListPersistenceTester extends Actor | ||
{ | ||
use _generated\ProductListPersistenceTesterActions; | ||
|
||
/** | ||
* @param int $idProductList | ||
* @param int $idCategory | ||
* | ||
* @return \Generated\Shared\Transfer\ProductListCategoryRelationTransfer | ||
*/ | ||
public function haveProductListCategory(int $idProductList, int $idCategory): ProductListCategoryRelationTransfer | ||
{ | ||
$productListProductCategoryEntity = SpyProductListCategoryQuery::create() | ||
->filterByFkProductList($idProductList) | ||
->filterByFkCategory($idCategory) | ||
->findOneOrCreate(); | ||
|
||
if ($productListProductCategoryEntity->isNew()) { | ||
$productListProductCategoryEntity->save(); | ||
} | ||
|
||
return (new ProductListCategoryRelationTransfer()) | ||
->setCategoryIds([$productListProductCategoryEntity->getFkCategory()]) | ||
->setIdProductList($productListProductCategoryEntity->getFkProductList()); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters