本文整理匯總了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();
}