1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
<?php
declare(strict_types=1);
namespace Doctrine\Tests\ORM\Functional;
use Doctrine\Common\Collections\Collection;
use Doctrine\Tests\OrmFunctionalTestCase;
use function count;
use function sprintf;
/**
* Base class for testing a many-to-many association mapping (without inheritance).
*/
class AbstractManyToManyAssociationTestCase extends OrmFunctionalTestCase
{
/** @var string */
protected $firstField;
/** @var string */
protected $secondField;
/** @var string */
protected $table;
public function assertForeignKeysContain($firstId, $secondId): void
{
self::assertEquals(1, $this->countForeignKeys($firstId, $secondId));
}
public function assertForeignKeysNotContain($firstId, $secondId): void
{
self::assertEquals(0, $this->countForeignKeys($firstId, $secondId));
}
protected function countForeignKeys($firstId, $secondId): int
{
return count($this->_em->getConnection()->fetchAllAssociative(sprintf(
<<<'SQL'
SELECT %s
FROM %s
WHERE %s = ?
AND %s = ?
SQL
,
$this->firstField,
$this->table,
$this->firstField,
$this->secondField,
), [$firstId, $secondId]));
}
public function assertCollectionEquals(Collection $first, Collection $second): bool
{
return $first->forAll(static fn ($k, $e): bool => $second->contains($e));
}
}
|