本文整理汇总了PHP中Prophecy\Prophecy\ObjectProphecy::quoteIdentifier方法的典型用法代码示例。如果您正苦于以下问题:PHP ObjectProphecy::quoteIdentifier方法的具体用法?PHP ObjectProphecy::quoteIdentifier怎么用?PHP ObjectProphecy::quoteIdentifier使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Prophecy\Prophecy\ObjectProphecy
的用法示例。
在下文中一共展示了ObjectProphecy::quoteIdentifier方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: setUp
/**
* Create a new database connection mock object for every test.
*
* @return void
*/
protected function setUp()
{
parent::setUp();
$this->connection = $this->prophesize(Connection::class);
$this->connection->quoteIdentifier(Argument::cetera())->will(function ($args) {
return '"' . join('"."', explode('.', $args[0])) . '"';
});
$this->connection->quote(Argument::cetera())->will(function ($args) {
return "'" . $args[0] . "'";
});
$this->connection->getDatabasePlatform()->willReturn(new MockPlatform());
$this->queryContext = GeneralUtility::makeInstance(QueryContext::class);
$this->expressionBuilder = GeneralUtility::makeInstance(ExpressionBuilder::class, $this->connection->reveal());
}
示例2: queryRestrictionsAreReevaluatedOnSettingsChangeForExecute
/**
* @test
*/
public function queryRestrictionsAreReevaluatedOnSettingsChangeForExecute()
{
$GLOBALS['TCA']['pages']['ctrl'] = ['tstamp' => 'tstamp', 'versioningWS' => true, 'delete' => 'deleted', 'crdate' => 'crdate', 'enablecolumns' => ['disabled' => 'hidden']];
$this->connection->quoteIdentifier(Argument::cetera())->willReturnArgument(0);
$this->connection->quoteIdentifiers(Argument::cetera())->willReturnArgument(0);
$this->connection->getExpressionBuilder()->willReturn(GeneralUtility::makeInstance(ExpressionBuilder::class, $this->connection->reveal()));
$concreteQueryBuilder = GeneralUtility::makeInstance(\Doctrine\DBAL\Query\QueryBuilder::class, $this->connection->reveal());
$subject = GeneralUtility::makeInstance(QueryBuilder::class, $this->connection->reveal(), null, $concreteQueryBuilder);
$subject->select('*')->from('pages')->where('uid=1');
$subject->getQueryContext()->setIgnoreEnableFields(true)->setIgnoredEnableFields(['disabled']);
$expectedSQL = 'SELECT * FROM pages WHERE (uid=1) AND (pages.deleted = 0)';
$this->connection->executeQuery($expectedSQL, Argument::cetera())->shouldBeCalled();
$subject->execute();
$subject->getQueryContext()->setIgnoreEnableFields(false);
$expectedSQL = 'SELECT * FROM pages WHERE (uid=1) AND ((pages.hidden = 0) AND (pages.deleted = 0))';
$this->connection->executeQuery($expectedSQL, Argument::cetera())->shouldBeCalled();
$subject->execute();
}