Passed
Pull Request — master (#123)
by Will
02:05
created

BaseElementTest::testGetHistoryFields()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 18
Code Lines 11

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
c 1
b 0
f 0
dl 0
loc 18
rs 9.4285
cc 1
eloc 11
nc 1
nop 0
1
<?php
2
3
namespace DNADesign\Elemental\Tests;
4
5
use DNADesign\Elemental\Extensions\ElementalPageExtension;
6
use DNADesign\Elemental\Models\ElementalArea;
7
use DNADesign\Elemental\Models\BaseElement;
8
use DNADesign\Elemental\Controllers\ElementController;
9
use DNADesign\Elemental\Tests\Src\TestElement;
10
use DNADesign\Elemental\Tests\Src\TestPage;
11
use SilverStripe\Core\Config\Config;
12
use SilverStripe\Forms\GridField\GridField;
13
use Page;
0 ignored issues
show
Bug introduced by
The type Page was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
14
use SilverStripe\CMS\Model\RedirectorPage;
15
use SilverStripe\Dev\FunctionalTest;
16
use DNADesign\Elemental\Models\ElementContent;
17
18
class BaseElementTest extends FunctionalTest
19
{
20
    protected static $fixture_file = 'ElementalPageExtensionTests.yml';
21
22
    protected static $required_extensions = [
23
        Page::class => [
24
            ElementalPageExtension::class,
25
        ]
26
    ];
27
28
    protected static $extra_dataobjects = [
29
        TestPage::class
30
    ];
31
32
    public function testSimpleClassName()
33
    {
34
        $element = $this->objFromFixture(ElementContent::class, 'content1');
35
36
        $this->assertEquals('dnadesign__elemental__models__elementcontent', $element->getSimpleClassName());
37
    }
38
39
    /**
40
     * Test to ensure backwards compatibility with old Anchor IDs.
41
     */
42
    public function testDisablePrettyAnchor()
43
    {
44
        Config::modify()->set(BaseElement::class, 'disable_pretty_anchor_name', true);
45
46
        $area = ElementalArea::create();
47
        $area->Elements()->add(BaseElement::create(array('Title' => 'Element 1', 'Sort' => 1)));
48
        $area->Elements()->add(BaseElement::create(array('Title' => 'Element 1', 'Sort' => 2)));
49
        $area->Elements()->add(BaseElement::create(array('Title' => 'Element 1', 'Sort' => 3)));
50
        $area->Elements()->add(BaseElement::create(array('Title' => 'Element 1', 'Sort' => 4)));
51
        $area->write();
52
53
        $recordSet = $area->Elements()->toArray();
54
        $this->assertEquals('e'.$recordSet[0]->ID, $recordSet[0]->getAnchor());
55
        $this->assertEquals('e'.$recordSet[1]->ID, $recordSet[1]->getAnchor());
56
        $this->assertEquals('e'.$recordSet[2]->ID, $recordSet[2]->getAnchor());
57
        $this->assertEquals('e'.$recordSet[3]->ID, $recordSet[3]->getAnchor());
58
    }
59
60
    /**
61
     * Test the stop-clashing logic if two BaseElement classes have the same $Title.
62
     */
63
    public function testSameTitle()
64
    {
65
        Config::modify()->set(BaseElement::class, 'enable_title_in_template', true);
66
67
        $area = ElementalArea::create();
68
        $area->Elements()->add(BaseElement::create(array('Title' => 'Element 1', 'Sort' => 1)));
69
        $area->Elements()->add(BaseElement::create(array('Title' => 'Element 1', 'Sort' => 2)));
70
        $area->Elements()->add(BaseElement::create(array('Title' => 'Element 1', 'Sort' => 3)));
71
        $area->Elements()->add(BaseElement::create(array('Title' => 'Element 1', 'Sort' => 4)));
72
        $area->write();
73
74
        $recordSet = $area->Elements()->toArray();
75
        foreach ($recordSet as $record) {
76
            // NOTE: This puts it into the $_anchor protected variable
77
            //       and caches it.
78
            $record->getAnchor();
79
        }
80
        $this->assertEquals('element-1', $recordSet[0]->getAnchor());
81
        $this->assertEquals('element-1-2', $recordSet[1]->getAnchor());
82
        $this->assertEquals('element-1-3', $recordSet[2]->getAnchor());
83
        $this->assertEquals('element-1-4', $recordSet[3]->getAnchor());
84
    }
85
86
    public function testGetCmsFields()
87
    {
88
        $this->markTestIncomplete();
89
    }
90
91
    public function testGetController()
92
    {
93
        $element = $this->objFromFixture(ElementContent::class, 'content1');
94
        $controller = $element->getController();
95
96
        $this->assertInstanceOf(ElementController::class, $controller);
97
98
        $this->assertEquals($element, $controller->getElement(), 'Controller has element');
99
        $this->assertEquals('Test Content', $controller->Title, 'Controller fallbacks to element');
100
    }
101
102
    public function testLink()
103
    {
104
        $this->markTestIncomplete();
105
    }
106
107
    public function testGetIcon()
108
    {
109
        $this->markTestIncomplete();
110
    }
111
112
    public function testGetHistoryFields()
113
    {
114
        $this->logInWithPermission();
115
116
        $element = $this->objFromFixture(ElementContent::class, 'content1');
117
        $history = $element->getHistoryFields()->fieldByName('History');
118
119
        $this->assertInstanceOf(GridField::class, $history);
120
        $this->assertEquals(1, $history->getList()->count());
121
122
        $element->HTML = '<p>Changed</p>';
123
        $element->write();
124
        $element->publishRecursive();
125
126
        $history = $element->getHistoryFields()->fieldByName('History');
127
128
        $this->assertInstanceOf(GridField::class, $history);
129
        $this->assertEquals(2, $history->getList()->count(), 'Publishing a new version creates a new record');
130
    }
131
132
    public function testStyleVariants()
133
    {
134
        $styles = [
135
            'option1' => 'Option 1',
136
            'option2' => 'Option 2'
137
        ];
138
139
        Config::modify()->set(ElementContent::class, 'styles', $styles);
140
        $element = $this->objFromFixture(ElementContent::class, 'content1');
141
142
        $this->assertEquals($styles,$element->getCMSFields()->dataFieldByName('Style')->getSource());
143
144
        $element->Style = 'option1';
145
        $this->assertEquals('option1', $element->getStyleVariant());
146
147
        // set a outdated style, should not add.
148
        $element->Style = 'old';
149
        $this->assertEquals('', $element->getStyleVariant());
150
    }
151
}
152