mirror of
https://github.com/silverstripe/silverstripe-fulltextsearch
synced 2024-10-22 14:05:29 +02:00
1728a62af5
Thanks to Marco Hermo and Brett Tasker for helping with this * Bump framework/cms to ^4.0@dev * WIP Silverstripe 4 compatibility fixes * more replacements and patches to migrate this module to 4.0 * Update composer.json * remove php <5.5 from travis.yml * WIP more SS4 compatibility fixes * WIP fix solr path to use DIR, avoid hardcoded module name * WIP respect current include path * WIP Namespacing and use on SearchIndex class * Namespacing for tests * WIP add namespaces to all classes * Second push of Test changes + namespacing * WIP split Solr files with multiple classes into single file / single class. Adjust namespaces * Fix PHP errors in test * break out search components with multiple classes into individual files and change namespaces * Update namespacing for Search indexes and variants in tests * Batch fixes for tests #2 * Update _config.php to use namespace * Use root namespace in referencing Apache_Solr_Document * Migrate task names so that the name is not fully qualified
88 lines
2.6 KiB
PHP
88 lines
2.6 KiB
PHP
<?php
|
|
|
|
use SilverStripe\CMS\Model\SiteTree;
|
|
use SilverStripe\FullTextSearch\Search\Indexes\SearchIndex_Recording;
|
|
use SilverStripe\Dev\SapphireTest;
|
|
|
|
class SearchVariantSiteTreeSubsitesPolyhomeTest_Item extends SiteTree
|
|
{
|
|
// TODO: Currently theres a failure if you addClass a non-table class
|
|
private static $db = array(
|
|
'TestText' => 'Varchar'
|
|
);
|
|
}
|
|
|
|
class SearchVariantSiteTreeSubsitesPolyhomeTest_Index extends SearchIndex_Recording
|
|
{
|
|
public function init()
|
|
{
|
|
$this->addClass('SearchVariantSiteTreeSubsitesPolyhomeTest_Item');
|
|
$this->addFilterField('TestText');
|
|
}
|
|
}
|
|
|
|
class SearchVariantSiteTreeSubsitesPolyhomeTest extends SapphireTest
|
|
{
|
|
private static $index = null;
|
|
|
|
private static $subsite_a = null;
|
|
private static $subsite_b = null;
|
|
|
|
public function setUp()
|
|
{
|
|
parent::setUp();
|
|
|
|
// Check subsites installed
|
|
if (!class_exists('Subsite') || !class_exists('SubsitePolyhome')) {
|
|
return $this->markTestSkipped('The subsites polyhome module is not installed');
|
|
}
|
|
|
|
if (self::$index === null) {
|
|
self::$index = singleton('SearchVariantSiteTreeSubsitesPolyhomeTest_Index');
|
|
}
|
|
|
|
if (self::$subsite_a === null) {
|
|
self::$subsite_a = new Subsite();
|
|
self::$subsite_a->write();
|
|
self::$subsite_b = new Subsite();
|
|
self::$subsite_b->write();
|
|
}
|
|
|
|
FullTextSearch::force_index_list(self::$index);
|
|
SearchUpdater::clear_dirty_indexes();
|
|
}
|
|
|
|
public function testSavingDirect()
|
|
{
|
|
// Initial add
|
|
|
|
$item = new SearchVariantSiteTreeSubsitesPolyhomeTest_Item();
|
|
$item->write();
|
|
|
|
SearchUpdater::flush_dirty_indexes();
|
|
$this->assertEquals(self::$index->getAdded(array('ID', '_subsite')), array(
|
|
array('ID' => $item->ID, '_subsite' => 0)
|
|
));
|
|
|
|
// Check that adding to subsites works
|
|
|
|
self::$index->reset();
|
|
|
|
$item->setField('AddToSubsite[0]', 1);
|
|
$item->setField('AddToSubsite['.(self::$subsite_a->ID).']', 1);
|
|
|
|
$item->write();
|
|
|
|
SearchUpdater::flush_dirty_indexes();
|
|
$this->assertEquals(self::$index->getAdded(array('ID', '_subsite')), array(
|
|
array('ID' => $item->ID, '_subsite' => 0),
|
|
array('ID' => $item->ID, '_subsite' => self::$subsite_a->ID)
|
|
));
|
|
$this->assertEquals(self::$index->deleted, array(
|
|
array('base' => 'SiteTree', 'id' => $item->ID, 'state' => array(
|
|
'SearchVariantVersioned' => 'Stage', 'SearchVariantSiteTreeSubsitesPolyhome' => self::$subsite_b->ID
|
|
))
|
|
));
|
|
}
|
|
}
|