Page Menu
Home
Phabricator
Search
Configure Global Search
Log In
Files
F1841536
ACLTest.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Size
7 KB
Subscribers
None
ACLTest.php
View Options
<?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
\D
AVACL
\X
ml
\P
roperty
\A
CL'
,
$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
\D
AVACL
\X
ml
\P
roperty
\A
cl'
;
$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
\D
AVACL
\X
ml
\P
roperty
\A
cl'
;
$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
\D
AVACL
\X
ml
\P
roperty
\A
cl'
;
$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
\D
AVACL
\X
ml
\P
roperty
\A
cl'
;
$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
Details
Attached
Mime Type
text/x-php
Expires
Tue, Jan 7, 3:58 PM (2 d, 10 h ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
914290
Default Alt Text
ACLTest.php (7 KB)
Attached To
rDAVCAL DokuWiki DAVCal PlugIn
Event Timeline
Log In to Comment