_schemaTool->createSchema(array( $this->_em->getClassMetadata(__NAMESPACE__ . '\DDC2012Item'), $this->_em->getClassMetadata(__NAMESPACE__ . '\DDC2012ItemPerson'), )); } public function testIssue() { $item = new DDC2012ItemPerson(); $item->tsv = array('word1', 'word2', 'word3'); $this->_em->persist($item); $this->_em->flush(); $this->_em->clear(); $item = $this->_em->find(get_class($item), $item->id); $this->assertArrayHasKey('convertToDatabaseValueSQL', DDC2012TsVectorType::$calls); $this->assertArrayHasKey('convertToDatabaseValue', DDC2012TsVectorType::$calls); $this->assertArrayHasKey('convertToPHPValue', DDC2012TsVectorType::$calls); $this->assertCount(1, DDC2012TsVectorType::$calls['convertToDatabaseValueSQL']); $this->assertCount(1, DDC2012TsVectorType::$calls['convertToDatabaseValue']); $this->assertCount(1, DDC2012TsVectorType::$calls['convertToPHPValue']); $this->assertInstanceOf(__NAMESPACE__ . '\DDC2012Item', $item); $this->assertEquals(array('word1', 'word2', 'word3'), $item->tsv); $item->tsv = array('word1', 'word2'); $this->_em->persist($item); $this->_em->flush(); $this->_em->clear(); $item = $this->_em->find(get_class($item), $item->id); $this->assertCount(2, DDC2012TsVectorType::$calls['convertToDatabaseValueSQL']); $this->assertCount(2, DDC2012TsVectorType::$calls['convertToDatabaseValue']); $this->assertCount(2, DDC2012TsVectorType::$calls['convertToPHPValue']); $this->assertInstanceOf(__NAMESPACE__ . '\DDC2012Item', $item); $this->assertEquals(array('word1', 'word2'), $item->tsv); } } /** * @Table(name="ddc2010_item") * @Entity * @InheritanceType("JOINED") * @DiscriminatorColumn(name="type_id", type="smallint") * @DiscriminatorMap({ * 1 = "DDC2012ItemPerson", * 2 = "DDC2012Item" * }) */ class DDC2012Item { /** * @Id * @GeneratedValue * @Column(type="integer") */ public $id; /** * @Column(name="tsv", type="tsvector", nullable=true) */ public $tsv; } /** * @Table(name="ddc2010_item_person") * @Entity */ class DDC2012ItemPerson extends DDC2012Item { } class DDC2012TsVectorType extends Type { const MYTYPE = 'tsvector'; public static $calls = array(); /** * {@inheritdoc} */ public function getSQLDeclaration(array $fieldDeclaration, AbstractPlatform $platform) { return $platform->getVarcharTypeDeclarationSQL($fieldDeclaration); } /** * {@inheritdoc} */ public function convertToDatabaseValue($value, AbstractPlatform $platform) { if (is_array($value)) { $value = implode(" ", $value); } self::$calls[__FUNCTION__][] = array( 'value' => $value, 'platform' => $platform, ); return $value; } /** * {@inheritdoc} */ public function convertToPHPValue($value, AbstractPlatform $platform) { self::$calls[__FUNCTION__][] = array( 'value' => $value, 'platform' => $platform, ); return explode(" ", strtolower($value)); } /** * {@inheritdoc} */ public function convertToDatabaseValueSQL($sqlExpr, AbstractPlatform $platform) { self::$calls[__FUNCTION__][] = array( 'sqlExpr' => $sqlExpr, 'platform' => $platform, ); // changed to upper expression to keep the test compatible with other Databases //sprintf('to_tsvector(%s)', $sqlExpr); return $platform->getUpperExpression($sqlExpr); } /** * {@inheritdoc} */ public function canRequireSQLConversion() { return true; } /** * {@inheritdoc} */ public function getName() { return self::MYTYPE; } }