Page MenuHomePhabricator

ACLTest.php
No OneTemporary

ACLTest.php

<?php
namespace Sabre\DAVACL\Xml\Property;
use Sabre\DAV;
use Sabre\HTTP;
use Sabre\DAV\Browser\HtmlOutputHelper;
class ACLTest extends \PHPUnit_Framework_TestCase {
function testConstruct() {
$acl = new Acl([]);
$this->assertInstanceOf('Sabre\DAVACL\Xml\Property\ACL', $acl);
}
function testSerializeEmpty() {
$acl = new Acl([]);
$xml = (new DAV\Server())->xml->write('{DAV:}root', $acl);
$expected = '<?xml version="1.0"?>
<d:root xmlns:d="DAV:" xmlns:s="http://sabredav.org/ns" />';
$this->assertXmlStringEqualsXmlString($expected, $xml);
}
function testSerialize() {
$privileges = [
[
'principal' => 'principals/evert',
'privilege' => '{DAV:}write',
],
[
'principal' => 'principals/foo',
'privilege' => '{DAV:}read',
'protected' => true,
],
];
$acl = new Acl($privileges);
$xml = (new DAV\Server())->xml->write('{DAV:}root', $acl, '/');
$expected = '<?xml version="1.0"?>
<d:root xmlns:d="DAV:" xmlns:s="http://sabredav.org/ns">
<d:ace>
<d:principal>
<d:href>/principals/evert/</d:href>
</d:principal>
<d:grant>
<d:privilege>
<d:write/>
</d:privilege>
</d:grant>
</d:ace>
<d:ace>
<d:principal>
<d:href>/principals/foo/</d:href>
</d:principal>
<d:grant>
<d:privilege>
<d:read/>
</d:privilege>
</d:grant>
<d:protected/>
</d:ace>
</d:root>
';
$this->assertXmlStringEqualsXmlString($expected, $xml);
}
function testSerializeSpecialPrincipals() {
$privileges = [
[
'principal' => '{DAV:}authenticated',
'privilege' => '{DAV:}write',
],
[
'principal' => '{DAV:}unauthenticated',
'privilege' => '{DAV:}write',
],
[
'principal' => '{DAV:}all',
'privilege' => '{DAV:}write',
],
];
$acl = new Acl($privileges);
$xml = (new DAV\Server())->xml->write('{DAV:}root', $acl, '/');
$expected = '<?xml version="1.0"?>
<d:root xmlns:d="DAV:" xmlns:s="http://sabredav.org/ns">
<d:ace>
<d:principal>
<d:authenticated/>
</d:principal>
<d:grant>
<d:privilege>
<d:write/>
</d:privilege>
</d:grant>
</d:ace>
<d:ace>
<d:principal>
<d:unauthenticated/>
</d:principal>
<d:grant>
<d:privilege>
<d:write/>
</d:privilege>
</d:grant>
</d:ace>
<d:ace>
<d:principal>
<d:all/>
</d:principal>
<d:grant>
<d:privilege>
<d:write/>
</d:privilege>
</d:grant>
</d:ace>
</d:root>
';
$this->assertXmlStringEqualsXmlString($expected, $xml);
}
function testUnserialize() {
$source = '<?xml version="1.0"?>
<d:root xmlns:d="DAV:">
<d:ace>
<d:principal>
<d:href>/principals/evert/</d:href>
</d:principal>
<d:grant>
<d:privilege>
<d:write/>
</d:privilege>
</d:grant>
</d:ace>
<d:ace>
<d:principal>
<d:href>/principals/foo/</d:href>
</d:principal>
<d:grant>
<d:privilege>
<d:read/>
</d:privilege>
</d:grant>
<d:protected/>
</d:ace>
</d:root>
';
$reader = new \Sabre\Xml\Reader();
$reader->elementMap['{DAV:}root'] = 'Sabre\DAVACL\Xml\Property\Acl';
$reader->xml($source);
$result = $reader->parse();
$result = $result['value'];
$this->assertInstanceOf('Sabre\\DAVACL\\Xml\\Property\\Acl', $result);
$expected = [
[
'principal' => '/principals/evert/',
'protected' => false,
'privilege' => '{DAV:}write',
],
[
'principal' => '/principals/foo/',
'protected' => true,
'privilege' => '{DAV:}read',
],
];
$this->assertEquals($expected, $result->getPrivileges());
}
/**
* @expectedException Sabre\DAV\Exception\BadRequest
*/
function testUnserializeNoPrincipal() {
$source = '<?xml version="1.0"?>
<d:root xmlns:d="DAV:">
<d:ace>
<d:grant>
<d:privilege>
<d:write/>
</d:privilege>
</d:grant>
</d:ace>
</d:root>
';
$reader = new \Sabre\Xml\Reader();
$reader->elementMap['{DAV:}root'] = 'Sabre\DAVACL\Xml\Property\Acl';
$reader->xml($source);
$result = $reader->parse();
}
function testUnserializeOtherPrincipal() {
$source = '<?xml version="1.0"?>
<d:root xmlns:d="DAV:">
<d:ace>
<d:grant>
<d:privilege>
<d:write/>
</d:privilege>
</d:grant>
<d:principal><d:authenticated /></d:principal>
</d:ace>
<d:ace>
<d:grant>
<d:ignoreme />
<d:privilege>
<d:write/>
</d:privilege>
</d:grant>
<d:principal><d:unauthenticated /></d:principal>
</d:ace>
<d:ace>
<d:grant>
<d:privilege>
<d:write/>
</d:privilege>
</d:grant>
<d:principal><d:all /></d:principal>
</d:ace>
</d:root>
';
$reader = new \Sabre\Xml\Reader();
$reader->elementMap['{DAV:}root'] = 'Sabre\DAVACL\Xml\Property\Acl';
$reader->xml($source);
$result = $reader->parse();
$result = $result['value'];
$this->assertInstanceOf('Sabre\\DAVACL\\Xml\\Property\\Acl', $result);
$expected = [
[
'principal' => '{DAV:}authenticated',
'protected' => false,
'privilege' => '{DAV:}write',
],
[
'principal' => '{DAV:}unauthenticated',
'protected' => false,
'privilege' => '{DAV:}write',
],
[
'principal' => '{DAV:}all',
'protected' => false,
'privilege' => '{DAV:}write',
],
];
$this->assertEquals($expected, $result->getPrivileges());
}
/**
* @expectedException Sabre\DAV\Exception\NotImplemented
*/
function testUnserializeDeny() {
$source = '<?xml version="1.0"?>
<d:root xmlns:d="DAV:">
<d:ignore-me />
<d:ace>
<d:deny>
<d:privilege>
<d:write/>
</d:privilege>
</d:deny>
<d:principal><d:href>/principals/evert</d:href></d:principal>
</d:ace>
</d:root>
';
$reader = new \Sabre\Xml\Reader();
$reader->elementMap['{DAV:}root'] = 'Sabre\DAVACL\Xml\Property\Acl';
$reader->xml($source);
$result = $reader->parse();
}
function testToHtml() {
$privileges = [
[
'principal' => 'principals/evert',
'privilege' => '{DAV:}write',
],
[
'principal' => 'principals/foo',
'privilege' => '{http://example.org/ns}read',
'protected' => true,
],
[
'principal' => '{DAV:}authenticated',
'privilege' => '{DAV:}write',
],
];
$acl = new Acl($privileges);
$html = new HtmlOutputHelper(
'/base/',
['DAV:' => 'd']
);
$expected =
'<table>' .
'<tr><th>Principal</th><th>Privilege</th><th></th></tr>' .
'<tr><td><a href="/base/principals/evert">/base/principals/evert</a></td><td><span title="{DAV:}write">d:write</span></td><td></td></tr>' .
'<tr><td><a href="/base/principals/foo">/base/principals/foo</a></td><td><span title="{http://example.org/ns}read">{http://example.org/ns}read</span></td><td>(protected)</td></tr>' .
'<tr><td><span title="{DAV:}authenticated">d:authenticated</span></td><td><span title="{DAV:}write">d:write</span></td><td></td></tr>' .
'</table>';
$this->assertEquals($expected, $acl->toHtml($html));
}
}

File Metadata

Mime Type
text/x-php
Expires
Dec 20 2024, 9:27 AM (4 w, 2 d ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
914290
Default Alt Text
ACLTest.php (7 KB)

Event Timeline