mirror of
https://github.com/silverstripe/silverstripe-dms
synced 2024-10-22 14:05:56 +02:00
MINOR Add more tests for classes in the "cms" code folder
This commit is contained in:
parent
e4bc553521
commit
b80aa645f8
@ -63,9 +63,12 @@ class DMSDocumentAddExistingField extends CompositeField
|
|||||||
/**
|
/**
|
||||||
* Sets or unsets the use of the "field" class in the template. The "field" class adds Javascript behaviour
|
* Sets or unsets the use of the "field" class in the template. The "field" class adds Javascript behaviour
|
||||||
* that causes unwelcome hiding side-effects when this Field is used within the link editor pop-up
|
* that causes unwelcome hiding side-effects when this Field is used within the link editor pop-up
|
||||||
|
*
|
||||||
|
* @return $this
|
||||||
*/
|
*/
|
||||||
public function setUseFieldClass($use = false)
|
public function setUseFieldClass($use = false)
|
||||||
{
|
{
|
||||||
$this->useFieldContext = $use;
|
$this->useFieldContext = $use;
|
||||||
|
return $this;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -106,7 +106,7 @@ class DMSGridFieldDeleteAction extends GridFieldDeleteAction implements
|
|||||||
}
|
}
|
||||||
|
|
||||||
$delete = false;
|
$delete = false;
|
||||||
if ($item->Pages()->Count() <= 1) {
|
if ($item->getRelatedPages()->count() <= 1) {
|
||||||
$delete = true;
|
$delete = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,7 +25,7 @@ class DMSSiteTreeExtension extends DataExtension
|
|||||||
$gridField->addExtraClass('documentsets');
|
$gridField->addExtraClass('documentsets');
|
||||||
|
|
||||||
$fields->addFieldToTab(
|
$fields->addFieldToTab(
|
||||||
'Root.Document Sets (' . $this->owner->DocumentSets()->Count() . ')',
|
'Root.Document Sets (' . $this->owner->DocumentSets()->count() . ')',
|
||||||
$gridField
|
$gridField
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ -53,6 +53,7 @@ class DMSSiteTreeExtension extends DataExtension
|
|||||||
/** @var DocumentSet $documentSet */
|
/** @var DocumentSet $documentSet */
|
||||||
$documents->merge($documentSet->getDocuments());
|
$documents->merge($documentSet->getDocuments());
|
||||||
}
|
}
|
||||||
|
$documents->removeDuplicates();
|
||||||
|
|
||||||
return $documents;
|
return $documents;
|
||||||
}
|
}
|
||||||
@ -67,11 +68,11 @@ class DMSSiteTreeExtension extends DataExtension
|
|||||||
|
|
||||||
// Only remove if record doesn't still exist on live stage.
|
// Only remove if record doesn't still exist on live stage.
|
||||||
if (!$existsOnOtherStage) {
|
if (!$existsOnOtherStage) {
|
||||||
$dmsDocuments = $this->owner->Documents();
|
$dmsDocuments = $this->owner->getAllDocuments();
|
||||||
foreach ($dmsDocuments as $document) {
|
foreach ($dmsDocuments as $document) {
|
||||||
//if the document is only associated with one page, i.e. only associated with this page
|
// If the document is only associated with one page, i.e. only associated with this page
|
||||||
if ($document->Pages()->Count() <= 1) {
|
if ($document->getRelatedPages()->count() <= 1) {
|
||||||
//delete the document before deleting this page
|
// Delete the document before deleting this page
|
||||||
$document->delete();
|
$document->delete();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -81,7 +82,7 @@ class DMSSiteTreeExtension extends DataExtension
|
|||||||
public function onBeforePublish()
|
public function onBeforePublish()
|
||||||
{
|
{
|
||||||
$embargoedDocuments = $this->owner->getAllDocuments()->filter('EmbargoedUntilPublished', true);
|
$embargoedDocuments = $this->owner->getAllDocuments()->filter('EmbargoedUntilPublished', true);
|
||||||
if ($embargoedDocuments->Count() > 0) {
|
if ($embargoedDocuments->count() > 0) {
|
||||||
foreach ($embargoedDocuments as $doc) {
|
foreach ($embargoedDocuments as $doc) {
|
||||||
$doc->EmbargoedUntilPublished = false;
|
$doc->EmbargoedUntilPublished = false;
|
||||||
$doc->write();
|
$doc->write();
|
||||||
|
38
tests/cms/DMSDocumentAddControllerTest.php
Normal file
38
tests/cms/DMSDocumentAddControllerTest.php
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
class DMSDocumentAddControllerTest extends FunctionalTest
|
||||||
|
{
|
||||||
|
protected static $fixture_file = 'dms/tests/dmstest.yml';
|
||||||
|
|
||||||
|
public function setUp()
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
$this->logInWithPermission();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCurrentPageReturnsSiteTree()
|
||||||
|
{
|
||||||
|
$controller = new DMSDocumentAddController;
|
||||||
|
$this->assertInstanceOf('SiteTree', $controller->currentPage());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetCurrentDocumentSetReturnsDocumentSet()
|
||||||
|
{
|
||||||
|
$controller = new DMSDocumentAddController;
|
||||||
|
$this->assertInstanceOf('DMSDocumentSet', $controller->getCurrentDocumentSet());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that extra allowed extensions are merged into the default upload field allowed extensions
|
||||||
|
*/
|
||||||
|
public function testGetAllowedExtensions()
|
||||||
|
{
|
||||||
|
$controller = new DMSDocumentAddController;
|
||||||
|
Config::inst()->remove('File', 'allowed_extensions');
|
||||||
|
Config::inst()->update('File', 'allowed_extensions', array('jpg', 'gif'));
|
||||||
|
$this->assertSame(array('jpg', 'gif'), $controller->getAllowedExtensions());
|
||||||
|
|
||||||
|
Config::inst()->update('DMSDocumentAddController', 'allowed_extensions', array('php', 'php5'));
|
||||||
|
$this->assertSame(array('jpg', 'gif', 'php', 'php5'), $controller->getAllowedExtensions());
|
||||||
|
}
|
||||||
|
}
|
22
tests/cms/DMSDocumentAddExistingFieldTest.php
Normal file
22
tests/cms/DMSDocumentAddExistingFieldTest.php
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
class DMSDocumentAddExistingFieldTest extends SapphireTest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The constructor should create a tree dropdown field
|
||||||
|
*/
|
||||||
|
public function testFieldContainsTreeDropdownField()
|
||||||
|
{
|
||||||
|
$field = new DMSDocumentAddExistingField('Test', 'Test');
|
||||||
|
$this->assertContainsOnlyInstancesOf('TreeDropdownField', $field->getChildren());
|
||||||
|
$this->assertSame('PageSelector', $field->getChildren()->first()->getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSetAndGetRecord()
|
||||||
|
{
|
||||||
|
$record = new DMSDocumentSet;
|
||||||
|
$field = new DMSDocumentAddExistingField('Test');
|
||||||
|
$field->setRecord($record);
|
||||||
|
$this->assertSame($record, $field->getRecord());
|
||||||
|
}
|
||||||
|
}
|
40
tests/cms/DMSUploadFieldTest.php
Normal file
40
tests/cms/DMSUploadFieldTest.php
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
class DMSUploadFieldTest extends SapphireTest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @var DMSUploadField
|
||||||
|
*/
|
||||||
|
protected $field;
|
||||||
|
|
||||||
|
public function setUp()
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
|
||||||
|
$this->field = new DMSUploadField('StubUploadField');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The validator is coded to always return true. Replace this test if this behaviour changes in future.
|
||||||
|
*/
|
||||||
|
public function testValidatorAlwaysReturnsTrue()
|
||||||
|
{
|
||||||
|
$this->assertTrue($this->field->validate('foo'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetItemHandler()
|
||||||
|
{
|
||||||
|
$this->assertInstanceOf('DMSUploadField_ItemHandler', $this->field->getItemHandler(123));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensure that the folder name can be get/set and that the value set is casted to a string
|
||||||
|
*/
|
||||||
|
public function testCanGetAndSetFolderName()
|
||||||
|
{
|
||||||
|
$this->field->setFolderName('qwerty');
|
||||||
|
$this->assertSame('qwerty', $this->field->getFolderName());
|
||||||
|
$this->field->setFolderName(123);
|
||||||
|
$this->assertSame('123', $this->field->getFolderName());
|
||||||
|
}
|
||||||
|
}
|
@ -3,7 +3,7 @@ SiteTree:
|
|||||||
Title: testPage1 has document sets
|
Title: testPage1 has document sets
|
||||||
URLSegment: s1
|
URLSegment: s1
|
||||||
s2:
|
s2:
|
||||||
Title: testPage2 has document sets
|
Title: testPage2 a document set
|
||||||
URLSegment: s2
|
URLSegment: s2
|
||||||
s3:
|
s3:
|
||||||
Title: testPage3 has document sets with embargoed docs
|
Title: testPage3 has document sets with embargoed docs
|
||||||
@ -17,6 +17,9 @@ SiteTree:
|
|||||||
s6:
|
s6:
|
||||||
Title: testPage6 has no sets
|
Title: testPage6 has no sets
|
||||||
URLSegment: s6
|
URLSegment: s6
|
||||||
|
s7:
|
||||||
|
Title: testPage7 has documents embargoed until publish
|
||||||
|
URLSegment: s7
|
||||||
DMSTag:
|
DMSTag:
|
||||||
t1:
|
t1:
|
||||||
Category: tag1
|
Category: tag1
|
||||||
@ -56,6 +59,9 @@ DMSDocumentSet:
|
|||||||
ds4:
|
ds4:
|
||||||
Title: Set containing embargoed documents
|
Title: Set containing embargoed documents
|
||||||
Page: =>SiteTree.s3
|
Page: =>SiteTree.s3
|
||||||
|
ds5:
|
||||||
|
Title: Set containing embargoed until publish documents
|
||||||
|
Page: =>SiteTree.s7
|
||||||
DMSDocument:
|
DMSDocument:
|
||||||
d1:
|
d1:
|
||||||
Filename: test-file-file-doesnt-exist-1
|
Filename: test-file-file-doesnt-exist-1
|
||||||
@ -98,6 +104,16 @@ DMSDocument:
|
|||||||
EmbargoedIndefinitely: true
|
EmbargoedIndefinitely: true
|
||||||
Folder: 5
|
Folder: 5
|
||||||
Sets: =>DMSDocumentSet.ds4
|
Sets: =>DMSDocumentSet.ds4
|
||||||
|
embargo_until_publish1:
|
||||||
|
Filename: embargo-until-publish1
|
||||||
|
EmbargoUntilPublish: true
|
||||||
|
Folder: 5
|
||||||
|
Sets: =>DMSDocumentSet.ds5
|
||||||
|
embargo_until_publish2:
|
||||||
|
Filename: embargo-until-publish2
|
||||||
|
EmbargoUntilPublish: true
|
||||||
|
Folder: 5
|
||||||
|
Sets: =>DMSDocumentSet.ds5
|
||||||
Member:
|
Member:
|
||||||
editor:
|
editor:
|
||||||
Name: editor
|
Name: editor
|
||||||
|
86
tests/extensions/DMSSiteTreeExtensionTest.php
Normal file
86
tests/extensions/DMSSiteTreeExtensionTest.php
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
class DMSSiteTreeExtensionTest extends SapphireTest
|
||||||
|
{
|
||||||
|
protected static $fixture_file = 'dms/tests/dmstest.yml';
|
||||||
|
|
||||||
|
protected $requiredExtensions = array(
|
||||||
|
'SiteTree' => array('DMSSiteTreeExtension')
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensure that setting the configuration property "documents_enabled" to false for a page type will prevent the
|
||||||
|
* CMS fields from being modified.
|
||||||
|
*
|
||||||
|
* Also ensures that a correctly named Document Sets GridField is added to the fields in the right place.
|
||||||
|
*
|
||||||
|
* Note: the (1) is the number of sets defined for this SiteTree in the fixture
|
||||||
|
*
|
||||||
|
* @dataProvider documentSetEnabledConfigProvider
|
||||||
|
*/
|
||||||
|
public function testCanDisableDocumentSetsTab($configSetting, $assertionMethod)
|
||||||
|
{
|
||||||
|
Config::inst()->update('SiteTree', 'documents_enabled', $configSetting);
|
||||||
|
$siteTree = $this->objFromFixture('SiteTree', 's2');
|
||||||
|
$this->$assertionMethod($siteTree->getCMSFields()->fieldByName('Root.Document Sets (1).Document Sets'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array[]
|
||||||
|
*/
|
||||||
|
public function documentSetEnabledConfigProvider()
|
||||||
|
{
|
||||||
|
return array(
|
||||||
|
array(true, 'assertNotNull'),
|
||||||
|
array(false, 'assertNull')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for the Document Sets GridField.
|
||||||
|
*
|
||||||
|
* Note: the (1) is the number of sets defined for this SiteTree in the fixture
|
||||||
|
*/
|
||||||
|
public function testDocumentSetsGridFieldIsCorrectlyConfigured()
|
||||||
|
{
|
||||||
|
Config::inst()->update('SiteTree', 'documents_enabled', true);
|
||||||
|
$siteTree = $this->objFromFixture('SiteTree', 's2');
|
||||||
|
$gridField = $siteTree->getCMSFields()->fieldByName('Root.Document Sets (1).Document Sets');
|
||||||
|
|
||||||
|
$this->assertInstanceOf('GridField', $gridField);
|
||||||
|
$this->assertTrue((bool) $gridField->hasClass('documentsets'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensure that a page title can be retrieved with the number of related documents it has (across all document sets).
|
||||||
|
*
|
||||||
|
* Note that the fixture has the same two documents attached to two different document sets, attached to this
|
||||||
|
* page, but we're expecting only two since they should be returned as unique only (rather than four).
|
||||||
|
*/
|
||||||
|
public function testGetTitleWithNumberOfDocuments()
|
||||||
|
{
|
||||||
|
$siteTree = $this->objFromFixture('SiteTree', 's1');
|
||||||
|
$this->assertSame('testPage1 has document sets (2)', $siteTree->getTitleWithNumberOfDocuments());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensure that documents marked as "embargo until publish" are unmarked as such when a page containing them is
|
||||||
|
* published
|
||||||
|
*/
|
||||||
|
public function testOnBeforePublishUnEmbargoesDocumentsSetAsEmbargoedUntilPublish()
|
||||||
|
{
|
||||||
|
$siteTree = $this->objFromFixture('SiteTree', 's7');
|
||||||
|
$siteTree->doPublish();
|
||||||
|
|
||||||
|
// Fixture defines this page as having two documents via one set
|
||||||
|
foreach (array('embargo-until-publish1', 'embargo-until-publish2') as $filename) {
|
||||||
|
$this->assertFalse(
|
||||||
|
(bool) $siteTree->getAllDocuments()
|
||||||
|
->filter('Filename', 'embargo-until-publish1')
|
||||||
|
->first()
|
||||||
|
->EmbargoedUntilPublished
|
||||||
|
);
|
||||||
|
}
|
||||||
|
$this->assertCount(0, $siteTree->getAllDocuments()->filter('EmbargoedUntilPublished', true));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user