1 | <?php |
||
3 | class DMSDocumentAdminTest extends FunctionalTest |
||
|
|||
4 | { |
||
5 | protected static $fixture_file = 'DMSDocumentAdminTest.yml'; |
||
6 | |||
7 | public function setUp() |
||
13 | |||
14 | /** |
||
15 | * Check that the default "add new" and "edit" buttons are gone, and replaced with our customised version of it |
||
16 | */ |
||
17 | public function testGridFieldHasCustomisedButtons() |
||
18 | { |
||
19 | $modelAdmin = new DMSDocumentAdmin; |
||
20 | $modelAdmin->init(); |
||
21 | |||
22 | $form = $modelAdmin->getEditForm(); |
||
23 | $gridFieldConfig = $form->Fields()->first()->getConfig(); |
||
24 | |||
25 | $replacements = array( |
||
26 | 'GridFieldAddNewButton'=>'DMSGridFieldAddNewButton', |
||
27 | 'GridFieldEditButton'=>'DMSGridFieldEditButton' |
||
28 | ); |
||
29 | |||
30 | foreach ($replacements as $oldClass => $newClass) { |
||
31 | // Our button is an instance of the original, so is returned when asking for the original |
||
32 | $newButtons = $gridFieldConfig->getComponentsByType($oldClass); |
||
33 | foreach ($newButtons as $key => $newButton) { |
||
34 | if ($newButton instanceof $newClass) { |
||
35 | // Remove our version for testing's sake |
||
36 | $newButtons->remove($newButton); |
||
37 | } |
||
38 | } |
||
39 | |||
40 | $this->assertCount(0, $newButtons, 'Original button is removed'); |
||
41 | $this->assertInstanceOf( |
||
42 | $newClass, |
||
43 | $gridFieldConfig->getComponentByType($newClass), |
||
44 | "Model admin for documents contains customised {$newClass} button" |
||
45 | ); |
||
46 | } |
||
47 | } |
||
48 | |||
49 | |||
50 | |||
51 | /** |
||
52 | * Quick check to ensure that the ModelAdmin endpoint is working |
||
53 | */ |
||
54 | public function testModelAdminEndpointWorks() |
||
55 | { |
||
56 | $this->assertEquals(200, $this->get('admin/documents')->getStatusCode()); |
||
57 | } |
||
58 | |||
59 | /** |
||
60 | * Check that the document sets GridField has a data column for the parent page title. Here we check for the |
||
61 | * Page title existing in the DOM, since "Page" is guaranteed to exist somewhere else. |
||
62 | */ |
||
63 | public function testDocumentSetsGridFieldHasParentPageColumn() |
||
69 | |||
70 | /** |
||
71 | * Checks that the document sets GridField has a data column which links to the DocumentSets tab on |
||
72 | * the actual page in the CMS |
||
73 | */ |
||
74 | public function testDocumentSetsGridFieldHasLinkToCMSPageEditor() |
||
82 | } |
||
83 |
You can fix this by adding a namespace to your class:
When choosing a vendor namespace, try to pick something that is not too generic to avoid conflicts with other libraries.