2017-05-02 14:49:41 +12:00
|
|
|
<?php
|
|
|
|
|
|
|
|
class DMSDocumentSetTest extends SapphireTest
|
|
|
|
{
|
|
|
|
protected static $fixture_file = 'dmstest.yml';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Ensure that getDocuments is extensible
|
|
|
|
*/
|
|
|
|
public function testGetDocumentsIsExtensible()
|
|
|
|
{
|
|
|
|
DMSDocumentSet::add_extension('StubRelatedDocumentExtension');
|
|
|
|
|
|
|
|
$set = new DMSDocumentSet;
|
|
|
|
$documents = $set->getDocuments();
|
|
|
|
|
|
|
|
$this->assertCount(1, $documents);
|
|
|
|
$this->assertSame('Extended', $documents->first()->Filename);
|
|
|
|
}
|
|
|
|
|
2017-05-09 10:13:13 +12:00
|
|
|
/**
|
|
|
|
* Test that the GridField for documents isn't shown until you've saved the set
|
|
|
|
*/
|
|
|
|
public function testGridFieldShowsWhenSetIsSaved()
|
|
|
|
{
|
|
|
|
$set = DMSDocumentSet::create();
|
|
|
|
|
|
|
|
// Not in database yet
|
|
|
|
$fields = $set->getCMSFields();
|
|
|
|
$this->assertNull($fields->fieldByName('Root.Main.Documents'));
|
|
|
|
$gridFieldNotice = $fields->fieldByName('Root.Main.GridFieldNotice');
|
|
|
|
$this->assertNotNull($gridFieldNotice);
|
|
|
|
$this->assertContains('Managing documents will be available', $gridFieldNotice->getContent());
|
|
|
|
|
|
|
|
// In the database
|
|
|
|
$set->Title = 'Testing';
|
|
|
|
$set->write();
|
|
|
|
$fields = $set->getCMSFields();
|
|
|
|
$this->assertNotNull($fields->fieldByName('Root.Main.Documents'));
|
|
|
|
$this->assertNull($fields->fieldByName('Root.Main.GridFieldNotice'));
|
|
|
|
}
|
|
|
|
|
2017-05-02 14:49:41 +12:00
|
|
|
public function testRelations()
|
|
|
|
{
|
|
|
|
$s1 = $this->objFromFixture('SiteTree', 's1');
|
|
|
|
$s2 = $this->objFromFixture('SiteTree', 's2');
|
|
|
|
$s4 = $this->objFromFixture('SiteTree', 's4');
|
|
|
|
|
|
|
|
$ds1 = $this->objFromFixture('DMSDocumentSet', 'ds1');
|
|
|
|
$ds2 = $this->objFromFixture('DMSDocumentSet', 'ds2');
|
|
|
|
$ds3 = $this->objFromFixture('DMSDocumentSet', 'ds3');
|
|
|
|
|
2018-04-11 14:10:55 +12:00
|
|
|
$this->assertCount(0, $s4->getDocumentSets(), 'Page 4 has no document sets associated');
|
|
|
|
$this->assertCount(2, $s1->getDocumentSets(), 'Page 1 has 2 document sets');
|
|
|
|
$this->assertEquals(array($ds1->ID, $ds2->ID), $s1->getDocumentSets()->column('ID'));
|
2017-05-02 14:49:41 +12:00
|
|
|
}
|
2017-05-09 10:13:13 +12:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Test that various components exist in the GridField config. See {@link DMSDocumentSet::getCMSFields} for context.
|
|
|
|
*/
|
|
|
|
public function testDocumentGridFieldConfig()
|
|
|
|
{
|
|
|
|
$set = $this->objFromFixture('DMSDocumentSet', 'ds1');
|
|
|
|
$fields = $set->getCMSFields();
|
|
|
|
$gridField = $fields->fieldByName('Root.Main.Documents');
|
|
|
|
$this->assertTrue((bool) $gridField->hasClass('documents'));
|
|
|
|
|
|
|
|
/** @var GridFieldConfig $config */
|
|
|
|
$config = $gridField->getConfig();
|
|
|
|
|
|
|
|
$this->assertNotNull($addNew = $config->getComponentByType('DMSGridFieldAddNewButton'));
|
|
|
|
$this->assertSame($set->ID, $addNew->getDocumentSetId());
|
|
|
|
|
|
|
|
if (class_exists('GridFieldPaginatorWithShowAll')) {
|
|
|
|
$this->assertNotNull($config->getComponentByType('GridFieldPaginatorWithShowAll'));
|
|
|
|
} else {
|
|
|
|
$paginator = $config->getComponentByType('GridFieldPaginator');
|
|
|
|
$this->assertNotNull($paginator);
|
|
|
|
$this->assertSame(15, $paginator->getItemsPerPage());
|
|
|
|
}
|
|
|
|
|
|
|
|
$sortableAssertion = class_exists('GridFieldSortableRows') ? 'assertNotNull' : 'assertNull';
|
|
|
|
$this->$sortableAssertion($config->getComponentByType('GridFieldSortableRows'));
|
|
|
|
}
|
2017-05-08 23:57:52 +12:00
|
|
|
|
2017-05-18 14:44:28 +12:00
|
|
|
/**
|
|
|
|
* Ensure that the display fields for the documents GridField can be returned
|
|
|
|
*/
|
|
|
|
public function testGetDocumentDisplayFields()
|
|
|
|
{
|
|
|
|
$document = $this->objFromFixture('DMSDocumentSet', 'ds1');
|
|
|
|
$this->assertInternalType('array', $document->getDocumentDisplayFields());
|
|
|
|
|
|
|
|
Config::inst()->update('DMSDocument', 'display_fields', array('apple' => 'Apple', 'orange' => 'Orange'));
|
|
|
|
$displayFields = $document->getDocumentDisplayFields();
|
|
|
|
$this->assertContains('Apple', $displayFields);
|
|
|
|
$this->assertContains('Orange', $displayFields);
|
2017-05-17 10:58:51 +12:00
|
|
|
$this->assertArrayHasKey('ManuallyAdded', $displayFields);
|
2017-05-18 14:44:28 +12:00
|
|
|
$this->assertContains('Added', $displayFields);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-05-17 10:58:51 +12:00
|
|
|
* Tests to ensure that the callback for formatting ManuallyAdded will return a nice label for the user
|
2017-05-18 14:44:28 +12:00
|
|
|
*/
|
2017-05-17 10:58:51 +12:00
|
|
|
public function testNiceFormattingForManuallyAddedInGridField()
|
2017-05-18 14:44:28 +12:00
|
|
|
{
|
|
|
|
$fieldFormatting = $this->objFromFixture('DMSDocumentSet', 'ds1')
|
|
|
|
->getCMSFields()
|
|
|
|
->fieldByName('Root.Main.Documents')
|
|
|
|
->getConfig()
|
|
|
|
->getComponentByType('GridFieldDataColumns')
|
|
|
|
->getFieldFormatting();
|
|
|
|
|
2017-05-17 10:58:51 +12:00
|
|
|
$this->assertArrayHasKey('ManuallyAdded', $fieldFormatting);
|
|
|
|
$this->assertTrue(is_callable($fieldFormatting['ManuallyAdded']));
|
2017-05-18 14:44:28 +12:00
|
|
|
|
2017-05-17 10:58:51 +12:00
|
|
|
$this->assertSame('Manually', $fieldFormatting['ManuallyAdded'](1));
|
|
|
|
$this->assertSame('Query Builder', $fieldFormatting['ManuallyAdded'](0));
|
2017-05-18 14:44:28 +12:00
|
|
|
}
|
|
|
|
|
2017-05-08 23:57:52 +12:00
|
|
|
/**
|
|
|
|
* Test that query fields can be added to the gridfield
|
|
|
|
*/
|
|
|
|
public function testAddQueryFields()
|
|
|
|
{
|
|
|
|
/** @var DMSDocumentSet $set */
|
|
|
|
$set = $this->objFromFixture('DMSDocumentSet', 'ds6');
|
|
|
|
/** @var FieldList $fields */
|
|
|
|
$fields = new FieldList(new TabSet('Root'));
|
|
|
|
/** @var FieldList $fields */
|
|
|
|
$set->addQueryFields($fields);
|
|
|
|
$keyValuePairs = $fields->dataFieldByName('KeyValuePairs');
|
|
|
|
$this->assertNotNull(
|
|
|
|
$keyValuePairs,
|
|
|
|
'addQueryFields() includes KeyValuePairs composite field'
|
|
|
|
);
|
|
|
|
$this->assertNotNull(
|
|
|
|
$keyValuePairs->fieldByName('KeyValuePairs[Title]'),
|
|
|
|
'addQueryFields() includes KeyValuePairs composite field'
|
|
|
|
);
|
2017-06-07 09:31:08 +12:00
|
|
|
|
|
|
|
// Test that the notification field exists
|
|
|
|
$this->assertNotNull($fields->fieldByName('Root.QueryBuilder.GridFieldNotice'));
|
|
|
|
|
|
|
|
// Test that Tags__ID field exists
|
|
|
|
$this->assertContains(
|
|
|
|
'Tags can be set in the taxonomy area,',
|
|
|
|
$keyValuePairs->fieldByName('KeyValuePairs[Tags__ID]')->RightTitle()
|
|
|
|
);
|
2017-05-08 23:57:52 +12:00
|
|
|
}
|
|
|
|
|
2017-06-06 16:53:52 +12:00
|
|
|
/**
|
|
|
|
* Ensure that the "direction" dropdown field has user friendly field labels
|
|
|
|
*/
|
|
|
|
public function testQueryBuilderDirectionFieldHasFriendlyLabels()
|
2017-05-08 23:57:52 +12:00
|
|
|
{
|
2017-06-06 16:53:52 +12:00
|
|
|
$fields = $this->objFromFixture('DMSDocumentSet', 'ds1')->getCMSFields();
|
2017-05-08 23:57:52 +12:00
|
|
|
|
2017-06-06 16:53:52 +12:00
|
|
|
$dropdown = $fields->fieldByName('Root.QueryBuilder')->FieldList()->filterByCallback(function ($field) {
|
|
|
|
return $field instanceof FieldGroup;
|
|
|
|
})->first()->fieldByName('SortByDirection');
|
2017-05-08 23:57:52 +12:00
|
|
|
|
2017-06-06 16:53:52 +12:00
|
|
|
$this->assertInstanceOf('DropdownField', $dropdown);
|
|
|
|
$source = $dropdown->getSource();
|
|
|
|
$this->assertContains('Ascending', $source);
|
|
|
|
$this->assertContains('Descending', $source);
|
2017-05-08 23:57:52 +12:00
|
|
|
}
|
|
|
|
|
2017-05-17 17:24:50 +12:00
|
|
|
/**
|
|
|
|
* Ensure that the configurable shortcode handler key is a hidden field in the CMS
|
|
|
|
*/
|
|
|
|
public function testShortcodeHandlerKeyFieldExists()
|
|
|
|
{
|
|
|
|
Config::inst()->update('DMS', 'shortcode_handler_key', 'unit-test');
|
|
|
|
|
2017-06-02 15:50:07 +12:00
|
|
|
$set = DMSDocumentSet::create(array('Title' => 'TestSet'));
|
2017-05-17 17:24:50 +12:00
|
|
|
$set->write();
|
|
|
|
|
|
|
|
$fields = $set->getCMSFields();
|
|
|
|
$field = $fields->fieldByName('Root.Main.DMSShortcodeHandlerKey');
|
|
|
|
|
|
|
|
$this->assertInstanceOf('HiddenField', $field);
|
|
|
|
$this->assertSame('unit-test', $field->Value());
|
|
|
|
}
|
|
|
|
|
2017-06-06 16:14:14 +12:00
|
|
|
/**
|
|
|
|
* Ensure that if the module is available, the orderable rows GridField component is added
|
|
|
|
*/
|
|
|
|
public function testDocumentsAreOrderable()
|
|
|
|
{
|
|
|
|
if (!class_exists('GridFieldSortableRows')) {
|
|
|
|
$this->markTestSkipped('Test requires undefinedoffset/sortablegridfield installed.');
|
|
|
|
}
|
|
|
|
|
|
|
|
$fields = $this->objFromFixture('DMSDocumentSet', 'ds1')->getCMSFields();
|
|
|
|
|
|
|
|
$gridField = $fields->fieldByName('Root.Main.Documents');
|
|
|
|
$this->assertInstanceOf('GridField', $gridField);
|
|
|
|
|
|
|
|
$this->assertInstanceOf(
|
|
|
|
'GridFieldSortableRows',
|
|
|
|
$gridField->getConfig()->getComponentByType('GridFieldSortableRows')
|
|
|
|
);
|
|
|
|
}
|
2017-05-17 17:24:50 +12:00
|
|
|
|
2017-05-08 23:57:52 +12:00
|
|
|
/**
|
|
|
|
* Test that extra documents are added after write
|
|
|
|
*/
|
|
|
|
public function testSaveLinkedDocuments()
|
|
|
|
{
|
|
|
|
/** @var DMSDocumentSet $set */
|
|
|
|
$set = $this->objFromFixture('DMSDocumentSet', 'dsSaveLinkedDocuments');
|
|
|
|
// Assert initially docs
|
|
|
|
$this->assertEquals(1, $set->getDocuments()->count(), 'Set has 1 document');
|
|
|
|
// Now apply the query and see if 2 extras were added with CreatedByID filter
|
|
|
|
$set->KeyValuePairs = '{"Filename":"extradoc3"}';
|
|
|
|
$set->saveLinkedDocuments();
|
|
|
|
$this->assertEquals(2, $set->getDocuments()->count(), 'Set has 2 documents');
|
|
|
|
}
|
2017-06-02 15:50:07 +12:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests that an exception is thrown if no title entered for a DMSDocumentSet.
|
|
|
|
* @expectedException ValidationException
|
|
|
|
*/
|
|
|
|
public function testExceptionOnNoTitleGiven()
|
|
|
|
{
|
2017-06-06 11:40:33 +12:00
|
|
|
DMSDocumentSet::create(array('Title' => ''))->write();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Ensure that when editing in a page context that the "page" field is removed, or is labelled "Show on page"
|
|
|
|
* otherwise
|
|
|
|
*/
|
|
|
|
public function testPageFieldRemovedWhenEditingInPageContext()
|
|
|
|
{
|
|
|
|
$set = $this->objFromFixture('DMSDocumentSet', 'ds1');
|
|
|
|
|
|
|
|
$fields = $set->getCMSFields();
|
|
|
|
$this->assertInstanceOf('DropdownField', $fields->fieldByName('Root.Main.PageID'));
|
|
|
|
|
|
|
|
$pageController = new CMSPageEditController;
|
|
|
|
$pageController->pushCurrent();
|
|
|
|
|
|
|
|
$fields = $set->getCMSFields();
|
|
|
|
$this->assertNull($fields->fieldByName('Root.Main.PageID'));
|
2017-06-02 15:50:07 +12:00
|
|
|
}
|
2017-06-14 11:05:19 +12:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests all crud permissions
|
|
|
|
*/
|
|
|
|
public function testPermissions()
|
|
|
|
{
|
|
|
|
if ($member = Member::currentUser()) {
|
|
|
|
$member->logout();
|
|
|
|
}
|
|
|
|
|
|
|
|
$set = $this->objFromFixture('DMSDocumentSet', 'ds1');
|
|
|
|
|
|
|
|
$this->assertFalse($set->canCreate());
|
|
|
|
$this->assertFalse($set->canDelete());
|
|
|
|
$this->assertFalse($set->canEdit());
|
|
|
|
$this->assertFalse($set->canView());
|
|
|
|
|
|
|
|
$this->logInWithPermission('CMS_ACCESS_DMSDocumentAdmin');
|
|
|
|
$this->assertTrue($set->canCreate());
|
|
|
|
$this->assertTrue($set->canDelete());
|
|
|
|
$this->assertTrue($set->canEdit());
|
|
|
|
$this->assertTrue($set->canView());
|
|
|
|
}
|
2017-05-02 14:49:41 +12:00
|
|
|
}
|