2011-03-22 10:00:53 +01:00
|
|
|
<?php
|
2016-06-16 06:57:19 +02:00
|
|
|
|
|
|
|
use SilverStripe\ORM\DB;
|
|
|
|
use SilverStripe\ORM\Versioning\Versioned;
|
2016-06-23 01:51:20 +02:00
|
|
|
use SilverStripe\MSSQL\MSSQLDatabase;
|
|
|
|
use SilverStripe\PostgreSQL\PostgreSQLDatabase;
|
2016-07-22 01:32:32 +02:00
|
|
|
use SilverStripe\CMS\Controllers\ContentController;
|
|
|
|
use SilverStripe\CMS\Search\SearchForm;
|
2016-08-23 04:36:06 +02:00
|
|
|
use SilverStripe\ORM\Search\FulltextSearchable;
|
|
|
|
use SilverStripe\Dev\FunctionalTest;
|
|
|
|
|
2011-03-22 10:00:53 +01:00
|
|
|
/**
|
2011-03-22 10:47:26 +01:00
|
|
|
* @package cms
|
2011-03-22 10:00:53 +01:00
|
|
|
* @subpackage testing
|
2016-01-06 00:42:07 +01:00
|
|
|
*
|
2011-03-22 10:00:53 +01:00
|
|
|
* @todo Fix unpublished pages check in testPublishedPagesMatchedByTitle()
|
|
|
|
* @todo All tests run on unpublished pages at the moment, due to the searchform not distinguishing between them
|
2016-01-06 00:42:07 +01:00
|
|
|
*
|
2011-11-07 23:27:25 +01:00
|
|
|
* Because this manipulates the test database in severe ways, I've renamed the test to force it to run last...
|
2011-03-22 10:00:53 +01:00
|
|
|
*/
|
2017-01-25 21:59:25 +01:00
|
|
|
class ZZZSearchFormTest extends FunctionalTest
|
|
|
|
{
|
|
|
|
|
|
|
|
protected static $fixture_file = 'SearchFormTest.yml';
|
|
|
|
|
|
|
|
protected $illegalExtensions = array(
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree' => array('SiteTreeSubsites', 'Translatable')
|
|
|
|
);
|
|
|
|
|
|
|
|
protected $mockController;
|
|
|
|
|
|
|
|
public function waitUntilIndexingFinished()
|
|
|
|
{
|
|
|
|
$schema = DB::get_schema();
|
|
|
|
if (method_exists($schema, 'waitUntilIndexingFinished')) {
|
|
|
|
$schema->waitUntilIndexingFinished();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setUpOnce()
|
|
|
|
{
|
|
|
|
// HACK Postgres doesn't refresh TSearch indexes when the schema changes after CREATE TABLE
|
|
|
|
// MySQL will need a different table type
|
|
|
|
self::kill_temp_db();
|
|
|
|
FulltextSearchable::enable();
|
|
|
|
self::create_temp_db();
|
|
|
|
$this->resetDBSchema(true);
|
|
|
|
parent::setUpOnce();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setUp()
|
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
$holderPage = $this->objFromFixture('SilverStripe\\CMS\\Model\\SiteTree', 'searchformholder');
|
|
|
|
$this->mockController = new ContentController($holderPage);
|
|
|
|
|
|
|
|
$this->waitUntilIndexingFinished();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Boolean
|
|
|
|
*/
|
|
|
|
protected function checkFulltextSupport()
|
|
|
|
{
|
|
|
|
$conn = DB::get_conn();
|
|
|
|
if (class_exists('SilverStripe\\MSSQL\\MSSQLDatabase') && $conn instanceof MSSQLDatabase) {
|
|
|
|
$supports = $conn->fullTextEnabled();
|
|
|
|
} else {
|
|
|
|
$supports = true;
|
|
|
|
}
|
|
|
|
if (!$supports) {
|
|
|
|
$this->markTestSkipped('Fulltext not supported by DB driver or setup');
|
|
|
|
}
|
|
|
|
return $supports;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSearchFormTemplateCanBeChanged()
|
|
|
|
{
|
|
|
|
if (!$this->checkFulltextSupport()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sf = new SearchForm($this->mockController, 'SilverStripe\\CMS\\Search\\SearchForm');
|
|
|
|
|
|
|
|
$sf->setTemplate('BlankPage');
|
|
|
|
|
|
|
|
$this->assertContains(
|
|
|
|
'<body class="SearchForm Form RequestHandler BlankPage">',
|
|
|
|
$sf->forTemplate()
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testPublishedPagesMatchedByTitle()
|
|
|
|
{
|
|
|
|
if (!$this->checkFulltextSupport()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sf = new SearchForm($this->mockController, 'SilverStripe\\CMS\\Search\\SearchForm');
|
|
|
|
|
|
|
|
$publishedPage = $this->objFromFixture('SilverStripe\\CMS\\Model\\SiteTree', 'publicPublishedPage');
|
|
|
|
$publishedPage->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
|
|
|
|
|
|
|
|
$this->waitUntilIndexingFinished();
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'publicPublishedPage'));
|
|
|
|
$this->assertContains(
|
|
|
|
$publishedPage->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Published pages are found by searchform'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testDoubleQuotesPublishedPagesMatchedByTitle()
|
|
|
|
{
|
|
|
|
if (!$this->checkFulltextSupport()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sf = new SearchForm($this->mockController, 'SilverStripe\\CMS\\Search\\SearchForm');
|
|
|
|
|
|
|
|
$publishedPage = $this->objFromFixture('SilverStripe\\CMS\\Model\\SiteTree', 'publicPublishedPage');
|
|
|
|
$publishedPage->Title = "finding butterflies";
|
|
|
|
$publishedPage->write();
|
|
|
|
$publishedPage->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
|
|
|
|
|
|
|
|
$this->waitUntilIndexingFinished();
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'"finding butterflies"'));
|
|
|
|
$this->assertContains(
|
|
|
|
$publishedPage->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Published pages are found by searchform'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testUnpublishedPagesNotIncluded()
|
|
|
|
{
|
|
|
|
if (!$this->checkFulltextSupport()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sf = new SearchForm($this->mockController, 'SilverStripe\\CMS\\Search\\SearchForm');
|
|
|
|
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'publicUnpublishedPage'));
|
|
|
|
$unpublishedPage = $this->objFromFixture('SilverStripe\\CMS\\Model\\SiteTree', 'publicUnpublishedPage');
|
|
|
|
$this->assertNotContains(
|
|
|
|
$unpublishedPage->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Unpublished pages are not found by searchform'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testPagesRestrictedToLoggedinUsersNotIncluded()
|
|
|
|
{
|
|
|
|
if (!$this->checkFulltextSupport()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sf = new SearchForm($this->mockController, 'SilverStripe\\CMS\\Search\\SearchForm');
|
|
|
|
|
|
|
|
$page = $this->objFromFixture('SilverStripe\\CMS\\Model\\SiteTree', 'restrictedViewLoggedInUsers');
|
|
|
|
$page->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'restrictedViewLoggedInUsers'));
|
|
|
|
$this->assertNotContains(
|
|
|
|
$page->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Page with "Restrict to logged in users" doesnt show without valid login'
|
|
|
|
);
|
|
|
|
|
|
|
|
$member = $this->objFromFixture('SilverStripe\\Security\\Member', 'randomuser');
|
|
|
|
$member->logIn();
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'restrictedViewLoggedInUsers'));
|
|
|
|
$this->assertContains(
|
|
|
|
$page->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Page with "Restrict to logged in users" shows if login is present'
|
|
|
|
);
|
|
|
|
$member->logOut();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testPagesRestrictedToSpecificGroupNotIncluded()
|
|
|
|
{
|
|
|
|
if (!$this->checkFulltextSupport()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sf = new SearchForm($this->mockController, 'SilverStripe\\CMS\\Search\\SearchForm');
|
|
|
|
|
|
|
|
$page = $this->objFromFixture('SilverStripe\\CMS\\Model\\SiteTree', 'restrictedViewOnlyWebsiteUsers');
|
|
|
|
$page->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'restrictedViewOnlyWebsiteUsers'));
|
|
|
|
$this->assertNotContains(
|
|
|
|
$page->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Page with "Restrict to these users" doesnt show without valid login'
|
|
|
|
);
|
|
|
|
|
|
|
|
$member = $this->objFromFixture('SilverStripe\\Security\\Member', 'randomuser');
|
|
|
|
$member->logIn();
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'restrictedViewOnlyWebsiteUsers'));
|
|
|
|
$this->assertNotContains(
|
|
|
|
$page->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Page with "Restrict to these users" doesnt show if logged in user is not in the right group'
|
|
|
|
);
|
|
|
|
$member->logOut();
|
|
|
|
|
|
|
|
$member = $this->objFromFixture('SilverStripe\\Security\\Member', 'websiteuser');
|
|
|
|
$member->logIn();
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'restrictedViewOnlyWebsiteUsers'));
|
|
|
|
$this->assertContains(
|
|
|
|
$page->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Page with "Restrict to these users" shows if user in this group is logged in'
|
|
|
|
);
|
|
|
|
$member->logOut();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testInheritedRestrictedPagesNotIncluded()
|
|
|
|
{
|
|
|
|
$sf = new SearchForm($this->mockController, 'SilverStripe\\CMS\\Search\\SearchForm');
|
|
|
|
|
|
|
|
$parent = $this->objFromFixture('SilverStripe\\CMS\\Model\\SiteTree', 'restrictedViewLoggedInUsers');
|
|
|
|
$parent->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
|
|
|
|
|
|
|
|
$page = $this->objFromFixture('SilverStripe\\CMS\\Model\\SiteTree', 'inheritRestrictedView');
|
|
|
|
$page->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'inheritRestrictedView'));
|
|
|
|
$this->assertNotContains(
|
|
|
|
$page->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Page inheriting "Restrict to loggedin users" doesnt show without valid login'
|
|
|
|
);
|
|
|
|
|
|
|
|
$member = $this->objFromFixture('SilverStripe\\Security\\Member', 'websiteuser');
|
|
|
|
$member->logIn();
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'inheritRestrictedView'));
|
|
|
|
$this->assertContains(
|
|
|
|
$page->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Page inheriting "Restrict to loggedin users" shows if user in this group is logged in'
|
|
|
|
);
|
|
|
|
$member->logOut();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testDisabledShowInSearchFlagNotIncludedForSiteTree()
|
|
|
|
{
|
|
|
|
if (!$this->checkFulltextSupport()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sf = new SearchForm($this->mockController, 'SilverStripe\\CMS\\Search\\SearchForm');
|
|
|
|
|
|
|
|
$page = $this->objFromFixture('SilverStripe\\CMS\\Model\\SiteTree', 'dontShowInSearchPage');
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'dontShowInSearchPage'));
|
|
|
|
$this->assertNotContains(
|
|
|
|
$page->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Page with "Show in Search" disabled doesnt show'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testDisabledShowInSearchFlagNotIncludedForFiles()
|
|
|
|
{
|
|
|
|
if (!$this->checkFulltextSupport()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sf = new SearchForm($this->mockController, 'SilverStripe\\CMS\\Search\\SearchForm');
|
|
|
|
|
|
|
|
$dontShowInSearchFile = $this->objFromFixture('SilverStripe\\Assets\\File', 'dontShowInSearchFile');
|
|
|
|
$dontShowInSearchFile->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
|
|
|
|
$showInSearchFile = $this->objFromFixture('SilverStripe\\Assets\\File', 'showInSearchFile');
|
|
|
|
$showInSearchFile->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
|
|
|
|
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'dontShowInSearchFile'));
|
|
|
|
$this->assertNotContains(
|
|
|
|
$dontShowInSearchFile->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'File with "Show in Search" disabled doesnt show'
|
|
|
|
);
|
|
|
|
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'showInSearchFile'));
|
|
|
|
$this->assertContains(
|
|
|
|
$showInSearchFile->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'File with "Show in Search" enabled can be found'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSearchTitleAndContentWithSpecialCharacters()
|
|
|
|
{
|
|
|
|
if (!$this->checkFulltextSupport()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (class_exists('SilverStripe\\PostgreSQL\\PostgreSQLDatabase') && DB::get_conn() instanceof PostgreSQLDatabase) {
|
|
|
|
$this->markTestSkipped("PostgreSQLDatabase doesn't support entity-encoded searches");
|
|
|
|
}
|
|
|
|
|
|
|
|
$sf = new SearchForm($this->mockController, 'SilverStripe\\CMS\\Search\\SearchForm');
|
|
|
|
|
|
|
|
$pageWithSpecialChars = $this->objFromFixture('SilverStripe\\CMS\\Model\\SiteTree', 'pageWithSpecialChars');
|
|
|
|
$pageWithSpecialChars->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
|
|
|
|
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'Brötchen'));
|
|
|
|
$this->assertContains(
|
|
|
|
$pageWithSpecialChars->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Published pages with umlauts in title are found'
|
|
|
|
);
|
|
|
|
|
|
|
|
$results = $sf->getResults(null, array('Search'=>'Bäcker'));
|
|
|
|
$this->assertContains(
|
|
|
|
$pageWithSpecialChars->ID,
|
|
|
|
$results->column('ID'),
|
|
|
|
'Published pages with htmlencoded umlauts in content are found'
|
|
|
|
);
|
|
|
|
}
|
2011-03-22 10:00:53 +01:00
|
|
|
}
|