2009-11-21 05:23:42 +00:00
|
|
|
<?php
|
2016-06-15 16:03:16 +12:00
|
|
|
|
|
|
|
use SilverStripe\ORM\DataObject;
|
2016-06-23 11:37:22 +12:00
|
|
|
use SilverStripe\Security\PermissionCheckboxSetField;
|
|
|
|
|
2009-11-21 05:23:42 +00:00
|
|
|
/**
|
2012-04-12 18:02:46 +12:00
|
|
|
* @package framework
|
2009-11-21 05:23:42 +00:00
|
|
|
* @subpackage tests
|
|
|
|
*/
|
|
|
|
class PermissionCheckboxSetFieldTest extends SapphireTest {
|
2013-03-21 19:48:54 +01:00
|
|
|
protected static $fixture_file = 'PermissionCheckboxSetFieldTest.yml';
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testHiddenPermissions() {
|
2009-11-21 05:23:42 +00:00
|
|
|
$f = new PermissionCheckboxSetField(
|
|
|
|
'Permissions',
|
|
|
|
'Permissions',
|
2016-06-23 11:37:22 +12:00
|
|
|
'SilverStripe\\Security\\Permission',
|
2009-11-21 05:23:42 +00:00
|
|
|
'GroupID'
|
|
|
|
);
|
|
|
|
$f->setHiddenPermissions(
|
2011-03-18 15:01:09 +13:00
|
|
|
array('NON-ADMIN')
|
2009-11-21 05:23:42 +00:00
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
$f->getHiddenPermissions(),
|
2011-03-18 15:01:09 +13:00
|
|
|
array('NON-ADMIN')
|
2009-11-21 05:23:42 +00:00
|
|
|
);
|
2011-03-18 15:01:09 +13:00
|
|
|
$this->assertContains('ADMIN', $f->Field());
|
|
|
|
$this->assertNotContains('NON-ADMIN', $f->Field());
|
2009-11-21 05:23:42 +00:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testSaveInto() {
|
2016-06-23 11:37:22 +12:00
|
|
|
$group = $this->objFromFixture('SilverStripe\\Security\\Group', 'group'); // tested group
|
|
|
|
$untouchable = $this->objFromFixture('SilverStripe\\Security\\Group', 'untouchable'); // group that should not change
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-12-16 05:43:59 +00:00
|
|
|
$field = new PermissionCheckboxSetField(
|
|
|
|
'Permissions',
|
|
|
|
'Permissions',
|
2016-06-23 11:37:22 +12:00
|
|
|
'SilverStripe\\Security\\Permission',
|
2009-12-16 05:43:59 +00:00
|
|
|
'GroupID',
|
|
|
|
$group
|
|
|
|
);
|
|
|
|
|
|
|
|
// get the number of permissions before we start
|
2016-06-23 11:37:22 +12:00
|
|
|
$baseCount = DataObject::get('SilverStripe\\Security\\Permission')->Count();
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-12-16 05:43:59 +00:00
|
|
|
// there are currently no permissions, save empty checkbox
|
|
|
|
$field->saveInto($group);
|
|
|
|
$group->flushCache();
|
|
|
|
$untouchable->flushCache();
|
|
|
|
$this->assertEquals($group->Permissions()->Count(), 0, 'The tested group has no permissions');
|
|
|
|
|
|
|
|
$this->assertEquals($untouchable->Permissions()->Count(), 1, 'The other group has one permission');
|
2015-02-25 15:21:33 +00:00
|
|
|
$this->assertEquals($untouchable->Permissions()->where("\"Code\"='ADMIN'")->Count(), 1,
|
2012-09-27 09:34:00 +12:00
|
|
|
'The other group has ADMIN permission');
|
2009-12-16 05:43:59 +00:00
|
|
|
|
2016-06-23 11:37:22 +12:00
|
|
|
$this->assertEquals(DataObject::get('SilverStripe\\Security\\Permission')->Count(), $baseCount, 'There are no orphaned permissions');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-12-16 05:43:59 +00:00
|
|
|
// add some permissions
|
|
|
|
$field->setValue(array(
|
|
|
|
'ADMIN'=>true,
|
2011-03-18 15:01:09 +13:00
|
|
|
'NON-ADMIN'=>true
|
2009-12-16 05:43:59 +00:00
|
|
|
));
|
|
|
|
|
|
|
|
$field->saveInto($group);
|
|
|
|
$group->flushCache();
|
|
|
|
$untouchable->flushCache();
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals($group->Permissions()->Count(), 2,
|
|
|
|
'The tested group has two permissions permission');
|
2015-02-25 15:21:33 +00:00
|
|
|
$this->assertEquals($group->Permissions()->where("\"Code\"='ADMIN'")->Count(), 1,
|
2012-09-27 09:34:00 +12:00
|
|
|
'The tested group has ADMIN permission');
|
2015-02-25 15:21:33 +00:00
|
|
|
$this->assertEquals($group->Permissions()->where("\"Code\"='NON-ADMIN'")->Count(), 1,
|
2012-09-27 09:34:00 +12:00
|
|
|
'The tested group has CMS_ACCESS_AssetAdmin permission');
|
2009-12-16 05:43:59 +00:00
|
|
|
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals($untouchable->Permissions()->Count(), 1,
|
|
|
|
'The other group has one permission');
|
2015-02-25 15:21:33 +00:00
|
|
|
$this->assertEquals($untouchable->Permissions()->where("\"Code\"='ADMIN'")->Count(), 1,
|
2012-09-27 09:34:00 +12:00
|
|
|
'The other group has ADMIN permission');
|
2009-12-16 05:43:59 +00:00
|
|
|
|
2016-06-23 11:37:22 +12:00
|
|
|
$this->assertEquals(DataObject::get('SilverStripe\\Security\\Permission')->Count(), $baseCount+2,
|
2012-09-27 09:34:00 +12:00
|
|
|
'There are no orphaned permissions');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-12-16 05:43:59 +00:00
|
|
|
// remove permission
|
|
|
|
$field->setValue(array(
|
|
|
|
'ADMIN'=>true,
|
|
|
|
));
|
|
|
|
|
|
|
|
$field->saveInto($group);
|
|
|
|
$group->flushCache();
|
|
|
|
$untouchable->flushCache();
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals($group->Permissions()->Count(), 1,
|
|
|
|
'The tested group has 1 permission');
|
2015-02-25 15:21:33 +00:00
|
|
|
$this->assertEquals($group->Permissions()->where("\"Code\"='ADMIN'")->Count(), 1,
|
2012-09-27 09:34:00 +12:00
|
|
|
'The tested group has ADMIN permission');
|
2009-12-16 05:43:59 +00:00
|
|
|
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals($untouchable->Permissions()->Count(), 1,
|
|
|
|
'The other group has one permission');
|
2015-02-25 15:21:33 +00:00
|
|
|
$this->assertEquals($untouchable->Permissions()->where("\"Code\"='ADMIN'")->Count(), 1,
|
2012-09-27 09:34:00 +12:00
|
|
|
'The other group has ADMIN permission');
|
2009-12-16 05:43:59 +00:00
|
|
|
|
2016-06-23 11:37:22 +12:00
|
|
|
$this->assertEquals(DataObject::get('SilverStripe\\Security\\Permission')->Count(), $baseCount+1,
|
2012-09-27 09:34:00 +12:00
|
|
|
'There are no orphaned permissions');
|
2009-12-16 05:43:59 +00:00
|
|
|
}
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|