getAnnotationReader(); $configuration = (new ConfigurationFactory($annotationReaderProvider, false))->createConfiguration(); $configuration->setMetadataDriverImpl( new class($annotationReader, [ConfigurationFactory::ENTITY_DIR]) extends AnnotationDriver { // Returning 'isTransient' = true means 'do not try to load Doctrine metadata' (which is true for most classes). // Here we override the method to check agains the ENTITY_DIR since phpstan-doctrine seems to sometimes pass // non-entity classes with non-Doctrine annotations to this methods. It may be fixed in future versions. public function isTransient($className) { $reflection = new ReflectionClass($className); if ($reflection && $reflection->getFileName()) { $entityDirRealpath = realpath(ConfigurationFactory::ENTITY_DIR); $fileRealpath = realpath($reflection->getFileName()); if (substr($fileRealpath, 0, strlen($entityDirRealpath)) !== $entityDirRealpath) { return true; } } return parent::isTransient($className); } } ); return EntityManager::create([ 'driverClass' => ConnectionFactory::DRIVER_CLASS, 'platform' => new MySQLPlatform(), ], $configuration);