| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-19 01:30:12 +01:00
										 |  |  | namespace Tests\Wallabag\Event\Subscriber; | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | use Doctrine\Common\EventManager; | 
					
						
							| 
									
										
										
										
											2022-12-14 14:36:29 +01:00
										 |  |  | use Doctrine\DBAL\Platforms\MySQLPlatform; | 
					
						
							|  |  |  | use Doctrine\DBAL\Platforms\PostgreSQLPlatform; | 
					
						
							| 
									
										
										
										
											2022-08-28 16:59:43 +02:00
										 |  |  | use Doctrine\DBAL\Platforms\SqlitePlatform; | 
					
						
							| 
									
										
										
										
											2022-09-01 20:54:56 +02:00
										 |  |  | use Doctrine\ORM\EntityManager; | 
					
						
							| 
									
										
										
										
											2015-12-22 10:16:34 +01:00
										 |  |  | use Doctrine\ORM\Event\LoadClassMetadataEventArgs; | 
					
						
							|  |  |  | use Doctrine\ORM\Mapping\ClassMetadata; | 
					
						
							| 
									
										
										
										
											2017-12-16 22:38:07 +01:00
										 |  |  | use PHPUnit\Framework\TestCase; | 
					
						
							| 
									
										
										
										
											2024-02-19 01:30:12 +01:00
										 |  |  | use Wallabag\Entity\User; | 
					
						
							|  |  |  | use Wallabag\Event\Subscriber\TablePrefixSubscriber; | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-16 22:38:07 +01:00
										 |  |  | class TablePrefixSubscriberTest extends TestCase | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     public function dataForPrefix() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  |         return [ | 
					
						
							| 
									
										
										
										
											2022-12-14 14:36:29 +01:00
										 |  |  |             ['wallabag_', User::class, '`user`', 'user', 'wallabag_user', '"wallabag_user"', new PostgreSQLPlatform()], | 
					
						
							|  |  |  |             ['wallabag_', User::class, '`user`', 'user', 'wallabag_user', '`wallabag_user`', new MySQLPlatform()], | 
					
						
							| 
									
										
										
										
											2022-09-01 20:54:56 +02:00
										 |  |  |             ['wallabag_', User::class, '`user`', 'user', 'wallabag_user', '"wallabag_user"', new SqlitePlatform()], | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-14 14:36:29 +01:00
										 |  |  |             ['wallabag_', User::class, 'user', 'user', 'wallabag_user', 'wallabag_user', new PostgreSQLPlatform()], | 
					
						
							|  |  |  |             ['wallabag_', User::class, 'user', 'user', 'wallabag_user', 'wallabag_user', new MySQLPlatform()], | 
					
						
							| 
									
										
										
										
											2022-09-01 20:54:56 +02:00
										 |  |  |             ['wallabag_', User::class, 'user', 'user', 'wallabag_user', 'wallabag_user', new SqlitePlatform()], | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-14 14:36:29 +01:00
										 |  |  |             ['', User::class, '`user`', 'user', 'user', '"user"', new PostgreSQLPlatform()], | 
					
						
							|  |  |  |             ['', User::class, '`user`', 'user', 'user', '`user`', new MySQLPlatform()], | 
					
						
							| 
									
										
										
										
											2022-09-01 20:54:56 +02:00
										 |  |  |             ['', User::class, '`user`', 'user', 'user', '"user"', new SqlitePlatform()], | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-14 14:36:29 +01:00
										 |  |  |             ['', User::class, 'user', 'user', 'user', 'user', new PostgreSQLPlatform()], | 
					
						
							|  |  |  |             ['', User::class, 'user', 'user', 'user', 'user', new MySQLPlatform()], | 
					
						
							| 
									
										
										
										
											2022-09-01 20:54:56 +02:00
										 |  |  |             ['', User::class, 'user', 'user', 'user', 'user', new SqlitePlatform()], | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @dataProvider dataForPrefix | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testPrefix($prefix, $entityName, $tableName, $tableNameExpected, $finalTableName, $finalTableNameQuoted, $platform) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-09-01 20:54:56 +02:00
										 |  |  |         $em = $this->getMockBuilder(EntityManager::class) | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  |             ->disableOriginalConstructor() | 
					
						
							|  |  |  |             ->getMock(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $subscriber = new TablePrefixSubscriber($prefix); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $metaClass = new ClassMetadata($entityName); | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  |         $metaClass->setPrimaryTable(['name' => $tableName]); | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $metaDataEvent = new LoadClassMetadataEventArgs($metaClass, $em); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-01 09:52:38 +02:00
										 |  |  |         $this->assertSame($tableNameExpected, $metaDataEvent->getClassMetadata()->getTableName()); | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $subscriber->loadClassMetadata($metaDataEvent); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-01 09:52:38 +02:00
										 |  |  |         $this->assertSame($finalTableName, $metaDataEvent->getClassMetadata()->getTableName()); | 
					
						
							|  |  |  |         $this->assertSame($finalTableNameQuoted, $metaDataEvent->getClassMetadata()->getQuotedTableName($platform)); | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @dataProvider dataForPrefix | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testSubscribedEvents($prefix, $entityName, $tableName, $tableNameExpected, $finalTableName, $finalTableNameQuoted, $platform) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-09-01 20:54:56 +02:00
										 |  |  |         $em = $this->getMockBuilder(EntityManager::class) | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  |             ->disableOriginalConstructor() | 
					
						
							|  |  |  |             ->getMock(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $metaClass = new ClassMetadata($entityName); | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  |         $metaClass->setPrimaryTable(['name' => $tableName]); | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $metaDataEvent = new LoadClassMetadataEventArgs($metaClass, $em); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $subscriber = new TablePrefixSubscriber($prefix); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $evm = new EventManager(); | 
					
						
							|  |  |  |         $evm->addEventSubscriber($subscriber); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $evm->dispatchEvent('loadClassMetadata', $metaDataEvent); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-01 09:52:38 +02:00
										 |  |  |         $this->assertSame($finalTableName, $metaDataEvent->getClassMetadata()->getTableName()); | 
					
						
							|  |  |  |         $this->assertSame($finalTableNameQuoted, $metaDataEvent->getClassMetadata()->getQuotedTableName($platform)); | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testPrefixManyToMany() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-09-01 20:54:56 +02:00
										 |  |  |         $em = $this->getMockBuilder(EntityManager::class) | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  |             ->disableOriginalConstructor() | 
					
						
							|  |  |  |             ->getMock(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $subscriber = new TablePrefixSubscriber('yo_'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-19 01:30:12 +01:00
										 |  |  |         $metaClass = new ClassMetadata('Wallabag\Entity\Entry'); | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  |         $metaClass->setPrimaryTable(['name' => 'entry']); | 
					
						
							|  |  |  |         $metaClass->mapManyToMany([ | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  |             'fieldName' => 'tags', | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  |             'joinTable' => ['name' => null, 'schema' => null], | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  |             'targetEntity' => 'Tag', | 
					
						
							|  |  |  |             'mappedBy' => null, | 
					
						
							|  |  |  |             'inversedBy' => 'entries', | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  |             'cascade' => ['persist'], | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  |             'indexBy' => null, | 
					
						
							|  |  |  |             'orphanRemoval' => false, | 
					
						
							|  |  |  |             'fetch' => 2, | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  |         ]); | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $metaDataEvent = new LoadClassMetadataEventArgs($metaClass, $em); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-01 09:52:38 +02:00
										 |  |  |         $this->assertSame('entry', $metaDataEvent->getClassMetadata()->getTableName()); | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $subscriber->loadClassMetadata($metaDataEvent); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-01 09:52:38 +02:00
										 |  |  |         $this->assertSame('yo_entry', $metaDataEvent->getClassMetadata()->getTableName()); | 
					
						
							|  |  |  |         $this->assertSame('yo_entry_tag', $metaDataEvent->getClassMetadata()->associationMappings['tags']['joinTable']['name']); | 
					
						
							| 
									
										
										
										
											2022-12-14 14:36:29 +01:00
										 |  |  |         $this->assertSame('yo_entry', $metaDataEvent->getClassMetadata()->getQuotedTableName(new MySQLPlatform())); | 
					
						
							| 
									
										
										
										
											2015-10-25 15:55:19 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | } |