2016-04-15 07:59:10 +02:00
|
|
|
<?php
|
|
|
|
|
2017-11-14 21:48:52 +01:00
|
|
|
namespace SilverStripe\FullTextSearch\Tests;
|
|
|
|
|
2017-12-04 21:11:51 +01:00
|
|
|
use Apache_Solr_Document;
|
|
|
|
use Page;
|
|
|
|
use SilverStripe\Assets\File;
|
|
|
|
use SilverStripe\Assets\Image;
|
|
|
|
use SilverStripe\CMS\Model\SiteTree;
|
|
|
|
use SilverStripe\Core\Config\Config;
|
|
|
|
use SilverStripe\Core\Injector\Injector;
|
2017-04-21 02:23:27 +02:00
|
|
|
use SilverStripe\Dev\SapphireTest;
|
2017-12-04 21:11:51 +01:00
|
|
|
use SilverStripe\FullTextSearch\Search\FullTextSearch;
|
|
|
|
use SilverStripe\FullTextSearch\Search\Processors\SearchUpdateImmediateProcessor;
|
|
|
|
use SilverStripe\FullTextSearch\Search\Processors\SearchUpdateProcessor;
|
|
|
|
use SilverStripe\FullTextSearch\Search\Updaters\SearchUpdater;
|
|
|
|
use SilverStripe\FullTextSearch\Search\Variants\SearchVariantSubsites;
|
|
|
|
use SilverStripe\FullTextSearch\Solr\Services\Solr4Service;
|
2017-04-21 03:18:37 +02:00
|
|
|
use SilverStripe\FullTextSearch\Tests\SolrIndexSubsitesTest\SolrIndexSubsitesTest_Index;
|
2017-12-04 21:11:51 +01:00
|
|
|
use SilverStripe\FullTextSearch\Tests\SolrIndexVersionedTest\SolrDocumentMatcher;
|
|
|
|
use SilverStripe\ORM\DataObject;
|
|
|
|
use SilverStripe\Subsites\Model\Subsite;
|
|
|
|
use SilverStripe\Versioned\Versioned;
|
2016-04-15 07:59:10 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Subsite specific solr testing
|
|
|
|
*/
|
2017-11-14 21:48:52 +01:00
|
|
|
class SolrIndexSubsitesTest extends SapphireTest
|
|
|
|
{
|
2017-12-04 21:11:51 +01:00
|
|
|
protected static $fixture_file = 'SolrIndexSubsitesTest/SolrIndexSubsitesTest.yml';
|
2016-04-15 07:59:10 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var SolrIndexSubsitesTest_Index
|
|
|
|
*/
|
|
|
|
private static $index = null;
|
|
|
|
|
|
|
|
protected $server = null;
|
|
|
|
|
2017-11-14 05:05:30 +01:00
|
|
|
protected function setUp()
|
2016-04-15 07:59:10 +02:00
|
|
|
{
|
2017-12-04 21:11:51 +01:00
|
|
|
// Prevent parent::setUp() crashing on db build
|
|
|
|
if (!class_exists(Subsite::class)) {
|
|
|
|
static::$fixture_file = null;
|
|
|
|
}
|
|
|
|
|
2017-11-14 05:05:30 +01:00
|
|
|
parent::setUp();
|
|
|
|
|
2017-12-04 21:11:51 +01:00
|
|
|
if (!class_exists(Subsite::class)) {
|
2017-04-22 11:36:40 +02:00
|
|
|
$this->markTestSkipped("These tests need the Subsite module installed to run");
|
2016-04-15 07:59:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$this->server = $_SERVER;
|
|
|
|
|
|
|
|
if (self::$index === null) {
|
2017-12-04 21:11:51 +01:00
|
|
|
self::$index = singleton(SolrIndexSubsitesTest_Index::class);
|
2016-04-15 07:59:10 +02:00
|
|
|
}
|
|
|
|
|
2017-12-03 23:53:37 +01:00
|
|
|
Config::modify()->set('Injector', 'SearchUpdateProcessor', array(
|
|
|
|
'class' => 'SearchUpdateImmediateProcessor'
|
|
|
|
));
|
2016-04-15 07:59:10 +02:00
|
|
|
|
|
|
|
FullTextSearch::force_index_list(self::$index);
|
|
|
|
SearchUpdater::clear_dirty_indexes();
|
|
|
|
}
|
|
|
|
|
2017-11-14 05:05:30 +01:00
|
|
|
protected function tearDown()
|
2016-04-15 07:59:10 +02:00
|
|
|
{
|
2017-11-14 05:05:30 +01:00
|
|
|
if ($this->server) {
|
2016-04-15 07:59:10 +02:00
|
|
|
$_SERVER = $this->server;
|
|
|
|
$this->server = null;
|
|
|
|
}
|
|
|
|
parent::tearDown();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function getServiceMock()
|
|
|
|
{
|
2017-12-04 21:11:51 +01:00
|
|
|
return $this->getMockBuilder(Solr4Service::class)
|
|
|
|
->setMethods(['addDocument', 'commit'])
|
|
|
|
->getMock();
|
2016-04-15 07:59:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param DataObject $object Item being added
|
|
|
|
* @param int $subsiteID
|
|
|
|
* @param string $stage
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
protected function getExpectedDocumentId($object, $subsiteID, $stage = null)
|
|
|
|
{
|
|
|
|
$id = $object->ID;
|
2017-04-26 12:52:20 +02:00
|
|
|
$class = DataObject::getSchema()->baseDataClass($object);
|
2016-04-15 07:59:10 +02:00
|
|
|
$variants = array();
|
|
|
|
|
|
|
|
// Check subsite
|
2017-12-04 21:11:51 +01:00
|
|
|
if (class_exists(Subsite::class)
|
|
|
|
&& DataObject::getSchema()->hasOneComponent($object->getClassName(), 'Subsite')
|
|
|
|
) {
|
2016-04-15 07:59:10 +02:00
|
|
|
$variants[] = '"SearchVariantSubsites":"' . $subsiteID. '"';
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check versioned
|
2017-11-14 21:48:52 +01:00
|
|
|
if ($stage) {
|
2016-04-15 07:59:10 +02:00
|
|
|
$variants[] = '"SearchVariantVersioned":"' . $stage . '"';
|
|
|
|
}
|
2017-12-04 21:11:51 +01:00
|
|
|
return $id . '-' . $class . '-{' . implode(',', $variants) . '}';
|
2016-04-15 07:59:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testPublishing()
|
|
|
|
{
|
|
|
|
// Setup mocks
|
|
|
|
$serviceMock = $this->getServiceMock();
|
|
|
|
self::$index->setService($serviceMock);
|
|
|
|
|
2017-12-04 21:11:51 +01:00
|
|
|
$subsite1 = $this->objFromFixture(Subsite::class, 'subsite1');
|
2016-04-15 07:59:10 +02:00
|
|
|
|
|
|
|
// Add records to first subsite
|
2017-12-04 21:11:51 +01:00
|
|
|
Versioned::set_stage(Versioned::DRAFT);
|
2016-04-15 07:59:10 +02:00
|
|
|
$_SERVER['HTTP_HOST'] = 'www.subsite1.com';
|
2017-12-04 21:11:51 +01:00
|
|
|
|
2016-04-15 07:59:10 +02:00
|
|
|
$file = new File();
|
|
|
|
$file->Title = 'My File';
|
|
|
|
$file->SubsiteID = $subsite1->ID;
|
|
|
|
$file->write();
|
2017-12-04 21:11:51 +01:00
|
|
|
|
2016-04-15 07:59:10 +02:00
|
|
|
$page = new Page();
|
|
|
|
$page->Title = 'My Page';
|
|
|
|
$page->SubsiteID = $subsite1->ID;
|
|
|
|
$page->write();
|
2017-12-04 21:11:51 +01:00
|
|
|
|
|
|
|
$doc1 = new Apache_Solr_Document([
|
2016-04-15 07:59:10 +02:00
|
|
|
'_documentid' => $this->getExpectedDocumentId($page, $subsite1->ID, 'Stage'),
|
|
|
|
'ClassName' => 'Page',
|
|
|
|
'SiteTree_Title' => 'My Page',
|
|
|
|
'_versionedstage' => 'Stage',
|
2017-12-04 21:11:51 +01:00
|
|
|
'_subsite' => $subsite1->ID,
|
|
|
|
]);
|
|
|
|
|
|
|
|
$doc2 = new Apache_Solr_Document([
|
2016-04-15 07:59:10 +02:00
|
|
|
'_documentid' => $this->getExpectedDocumentId($file, $subsite1->ID),
|
2017-12-04 21:11:51 +01:00
|
|
|
'ClassName' => File::class,
|
2016-04-15 07:59:10 +02:00
|
|
|
'File_Title' => 'My File',
|
2017-12-04 21:11:51 +01:00
|
|
|
'_subsite' => $subsite1->ID,
|
|
|
|
]);
|
|
|
|
|
|
|
|
$serviceMock
|
|
|
|
->expects($this->exactly(2))
|
|
|
|
->method('addDocument')
|
|
|
|
->withConsecutive($doc1, $doc2);
|
|
|
|
|
|
|
|
SearchUpdater::flush_dirty_indexes();
|
2016-04-15 07:59:10 +02:00
|
|
|
}
|
2016-12-08 12:47:42 +01:00
|
|
|
|
2017-11-14 21:48:52 +01:00
|
|
|
public function testCorrectSubsiteIDOnPageWrite()
|
|
|
|
{
|
2017-12-04 21:11:51 +01:00
|
|
|
$mockWrites = [
|
|
|
|
'3367:SiteTree:a:1:{s:22:"SearchVariantVersioned";s:4:"Live";}' => [
|
|
|
|
'base' => 'SilverStripe\\CMS\\Model\\SiteTree',
|
2016-12-08 12:47:42 +01:00
|
|
|
'class' => 'Page',
|
|
|
|
'id' => 3367,
|
2017-12-04 21:11:51 +01:00
|
|
|
'statefulids' => [
|
|
|
|
[
|
2016-12-08 12:47:42 +01:00
|
|
|
'id' => 3367,
|
2017-12-04 21:11:51 +01:00
|
|
|
'state' => [
|
2016-12-08 12:47:42 +01:00
|
|
|
'SearchVariantVersioned' => 'Live',
|
2017-12-04 21:11:51 +01:00
|
|
|
],
|
|
|
|
],
|
|
|
|
],
|
|
|
|
'fields' => [
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:ClassName' => 'Page',
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:LastEdited' => '2016-12-08 23:55:30',
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:Created' => '2016-11-30 05:23:58',
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:URLSegment' => 'test',
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:Title' => 'Test Title',
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:Content' => '<p>test content</p>',
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:MetaDescription' => 'a solr test',
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:ShowInMenus' => 1,
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:ShowInSearch' => 1,
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:Sort' => 77,
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:HasBrokenFile' => 0,
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:HasBrokenLink' => 0,
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:CanViewType' => 'Inherit',
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:CanEditType' => 'Inherit',
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:Locale' => 'en_NZ',
|
|
|
|
'SilverStripe\\CMS\\Model\\SiteTree:SubsiteID' => 0,
|
2016-12-08 12:47:42 +01:00
|
|
|
'Page:ID' => 3367,
|
|
|
|
'Page:MetaKeywords' => null,
|
2017-12-04 21:11:51 +01:00
|
|
|
],
|
|
|
|
],
|
|
|
|
];
|
2016-12-08 12:47:42 +01:00
|
|
|
$variant = new SearchVariantSubsites();
|
|
|
|
$tmpMockWrites = $mockWrites;
|
|
|
|
$variant->extractManipulationWriteState($tmpMockWrites);
|
2017-12-04 21:11:51 +01:00
|
|
|
|
2017-11-14 21:48:52 +01:00
|
|
|
foreach ($tmpMockWrites as $mockWrite) {
|
2016-12-08 12:47:42 +01:00
|
|
|
$this->assertCount(1, $mockWrite['statefulids']);
|
|
|
|
$statefulIDs = array_shift($mockWrite['statefulids']);
|
2017-12-04 21:11:51 +01:00
|
|
|
|
|
|
|
$this->assertArrayHasKey(SearchVariantSubsites::class, $statefulIDs['state']);
|
|
|
|
$this->assertEquals(0, $statefulIDs['state'][SearchVariantSubsites::class]);
|
2016-12-08 12:47:42 +01:00
|
|
|
}
|
|
|
|
|
2017-12-04 21:11:51 +01:00
|
|
|
$subsite = $this->objFromFixture(Subsite::class, 'subsite1');
|
2016-12-08 12:47:42 +01:00
|
|
|
$tmpMockWrites = $mockWrites;
|
2017-12-04 21:11:51 +01:00
|
|
|
$tmpMockWrites['3367:SiteTree:a:1:{s:22:"SearchVariantVersioned";s:4:"Live";}']['fields'][SiteTree::class . ':SubsiteID'] = $subsite->ID;
|
2016-12-08 12:47:42 +01:00
|
|
|
|
|
|
|
$variant->extractManipulationWriteState($tmpMockWrites);
|
2017-11-14 21:48:52 +01:00
|
|
|
foreach ($tmpMockWrites as $mockWrite) {
|
2016-12-08 12:47:42 +01:00
|
|
|
$this->assertCount(1, $mockWrite['statefulids']);
|
|
|
|
$statefulIDs = array_shift($mockWrite['statefulids']);
|
2017-12-04 21:11:51 +01:00
|
|
|
|
|
|
|
$this->assertArrayHasKey(SearchVariantSubsites::class, $statefulIDs['state']);
|
|
|
|
$this->assertEquals($subsite->ID, $statefulIDs['state'][SearchVariantSubsites::class]);
|
2016-12-08 12:47:42 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-14 21:48:52 +01:00
|
|
|
public function testCorrectSubsiteIDOnFileWrite()
|
|
|
|
{
|
2017-12-04 21:11:51 +01:00
|
|
|
$subsiteIDs = ['0'] + $this->allFixtureIDs(Subsite::class);
|
|
|
|
$mockWrites = [
|
|
|
|
'35910:File:a:0:{}' => [
|
|
|
|
'base' => File::class,
|
|
|
|
'class' => File::class,
|
2016-12-08 12:47:42 +01:00
|
|
|
'id' => 35910,
|
2017-12-04 21:11:51 +01:00
|
|
|
'statefulids' => [
|
|
|
|
[
|
2016-12-08 12:47:42 +01:00
|
|
|
'id' => 35910,
|
2017-12-04 21:11:51 +01:00
|
|
|
'state' => [],
|
|
|
|
],
|
|
|
|
],
|
|
|
|
'fields' => [
|
|
|
|
File::class . ':ClassName' => Image::class,
|
|
|
|
File::class . ':ShowInSearch' => 1,
|
|
|
|
File::class . ':ParentID' => 26470,
|
|
|
|
File::class . ':Filename' => 'assets/Uploads/pic.jpg',
|
|
|
|
File::class . ':Name' => 'pic.jpg',
|
|
|
|
File::class . ':Title' => 'pic',
|
|
|
|
File::class . ':SubsiteID' => 0,
|
|
|
|
File::class . ':OwnerID' => 661,
|
|
|
|
File::class . ':CurrentVersionID' => 22038,
|
|
|
|
File::class . ':LastEdited' => '2016-12-09 00:35:13',
|
|
|
|
],
|
|
|
|
],
|
|
|
|
];
|
2016-12-08 12:47:42 +01:00
|
|
|
$variant = new SearchVariantSubsites();
|
|
|
|
$tmpMockWrites = $mockWrites;
|
|
|
|
$variant->extractManipulationWriteState($tmpMockWrites);
|
2017-11-14 21:48:52 +01:00
|
|
|
foreach ($tmpMockWrites as $mockWrite) {
|
2016-12-08 12:47:42 +01:00
|
|
|
$this->assertCount(count($subsiteIDs), $mockWrite['statefulids']);
|
|
|
|
foreach ($mockWrite['statefulids'] as $statefulIDs) {
|
2017-12-04 21:11:51 +01:00
|
|
|
$this->assertContains(
|
|
|
|
$statefulIDs['state'][SearchVariantSubsites::class],
|
|
|
|
$subsiteIDs,
|
|
|
|
sprintf(
|
|
|
|
'Failed to assert that %s is in list of valid subsites: %s',
|
|
|
|
$statefulIDs['state'][SearchVariantSubsites::class],
|
|
|
|
implode(', ', $subsiteIDs)
|
|
|
|
)
|
2016-12-08 12:47:42 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-12-04 21:11:51 +01:00
|
|
|
$subsite = $this->objFromFixture(Subsite::class, 'subsite1');
|
2016-12-08 12:47:42 +01:00
|
|
|
$tmpMockWrites = $mockWrites;
|
2017-12-04 21:11:51 +01:00
|
|
|
$tmpMockWrites['35910:File:a:0:{}']['fields'][File::class . ':SubsiteID'] = $subsite->ID;
|
2016-12-08 12:47:42 +01:00
|
|
|
|
|
|
|
$variant->extractManipulationWriteState($tmpMockWrites);
|
2017-11-14 21:48:52 +01:00
|
|
|
foreach ($tmpMockWrites as $mockWrite) {
|
2016-12-08 12:47:42 +01:00
|
|
|
$this->assertCount(1, $mockWrite['statefulids']);
|
|
|
|
$statefulIDs = array_shift($mockWrite['statefulids']);
|
2017-12-04 21:11:51 +01:00
|
|
|
$this->assertEquals($subsite->ID, $statefulIDs['state'][SearchVariantSubsites::class]);
|
2016-12-08 12:47:42 +01:00
|
|
|
}
|
|
|
|
}
|
2016-04-15 07:59:10 +02:00
|
|
|
}
|