mirror of
https://git.friendi.ca/friendica/friendica-addons.git
synced 2024-11-15 06:13:55 +00:00
254 lines
6.5 KiB
PHP
254 lines
6.5 KiB
PHP
|
<?php
|
||
|
|
||
|
require_once 'Sabre/CalDAV/TestUtil.php';
|
||
|
require_once 'Sabre/DAVACL/MockPrincipalBackend.php';
|
||
|
|
||
|
class Sabre_CalDAV_CalendarTest extends PHPUnit_Framework_TestCase {
|
||
|
|
||
|
/**
|
||
|
* @var Sabre_CalDAV_Backend_PDO
|
||
|
*/
|
||
|
protected $backend;
|
||
|
protected $principalBackend;
|
||
|
/**
|
||
|
* @var Sabre_CalDAV_Calendar
|
||
|
*/
|
||
|
protected $calendar;
|
||
|
/**
|
||
|
* @var array
|
||
|
*/
|
||
|
protected $calendars;
|
||
|
|
||
|
function setup() {
|
||
|
|
||
|
if (!SABRE_HASSQLITE) $this->markTestSkipped('SQLite driver is not available');
|
||
|
$this->backend = Sabre_CalDAV_TestUtil::getBackend();
|
||
|
$this->principalBackend = new Sabre_DAVACL_MockPrincipalBackend();
|
||
|
|
||
|
$this->calendars = $this->backend->getCalendarsForUser('principals/user1');
|
||
|
$this->assertEquals(2, count($this->calendars));
|
||
|
$this->calendar = new Sabre_CalDAV_Calendar($this->principalBackend, $this->backend, $this->calendars[0]);
|
||
|
|
||
|
|
||
|
}
|
||
|
|
||
|
function teardown() {
|
||
|
|
||
|
unset($this->backend);
|
||
|
|
||
|
}
|
||
|
|
||
|
function testSimple() {
|
||
|
|
||
|
$this->assertEquals($this->calendars[0]['uri'], $this->calendar->getName());
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @depends testSimple
|
||
|
*/
|
||
|
function testUpdateProperties() {
|
||
|
|
||
|
$result = $this->calendar->updateProperties(array(
|
||
|
'{DAV:}displayname' => 'NewName',
|
||
|
));
|
||
|
|
||
|
$this->assertEquals(true, $result);
|
||
|
|
||
|
$calendars2 = $this->backend->getCalendarsForUser('principals/user1');
|
||
|
$this->assertEquals('NewName',$calendars2[0]['{DAV:}displayname']);
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @depends testSimple
|
||
|
*/
|
||
|
function testGetProperties() {
|
||
|
|
||
|
$question = array(
|
||
|
'{DAV:}owner',
|
||
|
'{urn:ietf:params:xml:ns:caldav}supported-calendar-component-set',
|
||
|
'{urn:ietf:params:xml:ns:caldav}supported-calendar-data',
|
||
|
'{urn:ietf:params:xml:ns:caldav}supported-collation-set',
|
||
|
);
|
||
|
|
||
|
$result = $this->calendar->getProperties($question);
|
||
|
|
||
|
foreach($question as $q) $this->assertArrayHasKey($q,$result);
|
||
|
|
||
|
$this->assertEquals(array('VEVENT','VTODO'), $result['{urn:ietf:params:xml:ns:caldav}supported-calendar-component-set']->getValue());
|
||
|
|
||
|
$this->assertTrue($result['{urn:ietf:params:xml:ns:caldav}supported-collation-set'] instanceof Sabre_CalDAV_Property_SupportedCollationSet);
|
||
|
|
||
|
$this->assertTrue($result['{DAV:}owner'] instanceof Sabre_DAVACL_Property_Principal);
|
||
|
$this->assertEquals('principals/user1', $result['{DAV:}owner']->getHref());
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @expectedException Sabre_DAV_Exception_NotFound
|
||
|
* @depends testSimple
|
||
|
*/
|
||
|
function testGetChildNotFound() {
|
||
|
|
||
|
$this->calendar->getChild('randomname');
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @depends testSimple
|
||
|
*/
|
||
|
function testGetChildren() {
|
||
|
|
||
|
$children = $this->calendar->getChildren();
|
||
|
$this->assertEquals(1,count($children));
|
||
|
|
||
|
$this->assertTrue($children[0] instanceof Sabre_CalDAV_CalendarObject);
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @depends testGetChildren
|
||
|
*/
|
||
|
function testChildExists() {
|
||
|
|
||
|
$this->assertFalse($this->calendar->childExists('foo'));
|
||
|
|
||
|
$children = $this->calendar->getChildren();
|
||
|
$this->assertTrue($this->calendar->childExists($children[0]->getName()));
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @expectedException Sabre_DAV_Exception_MethodNotAllowed
|
||
|
*/
|
||
|
function testCreateDirectory() {
|
||
|
|
||
|
$this->calendar->createDirectory('hello');
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @expectedException Sabre_DAV_Exception_MethodNotAllowed
|
||
|
*/
|
||
|
function testSetName() {
|
||
|
|
||
|
$this->calendar->setName('hello');
|
||
|
|
||
|
}
|
||
|
|
||
|
function testGetLastModified() {
|
||
|
|
||
|
$this->assertNull($this->calendar->getLastModified());
|
||
|
|
||
|
}
|
||
|
|
||
|
function testCreateFile() {
|
||
|
|
||
|
$file = fopen('php://memory','r+');
|
||
|
fwrite($file,Sabre_CalDAV_TestUtil::getTestCalendarData());
|
||
|
rewind($file);
|
||
|
|
||
|
$this->calendar->createFile('hello',$file);
|
||
|
|
||
|
$file = $this->calendar->getChild('hello');
|
||
|
$this->assertTrue($file instanceof Sabre_CalDAV_CalendarObject);
|
||
|
|
||
|
}
|
||
|
|
||
|
function testCreateFileNoSupportedComponents() {
|
||
|
|
||
|
$file = fopen('php://memory','r+');
|
||
|
fwrite($file,Sabre_CalDAV_TestUtil::getTestCalendarData());
|
||
|
rewind($file);
|
||
|
|
||
|
$calendar = new Sabre_CalDAV_Calendar($this->principalBackend, $this->backend, $this->calendars[1]);
|
||
|
$calendar->createFile('hello',$file);
|
||
|
|
||
|
$file = $calendar->getChild('hello');
|
||
|
$this->assertTrue($file instanceof Sabre_CalDAV_CalendarObject);
|
||
|
|
||
|
}
|
||
|
|
||
|
function testDelete() {
|
||
|
|
||
|
$this->calendar->delete();
|
||
|
|
||
|
$calendars = $this->backend->getCalendarsForUser('principals/user1');
|
||
|
$this->assertEquals(1, count($calendars));
|
||
|
}
|
||
|
|
||
|
function testGetOwner() {
|
||
|
|
||
|
$this->assertEquals('principals/user1',$this->calendar->getOwner());
|
||
|
|
||
|
}
|
||
|
|
||
|
function testGetGroup() {
|
||
|
|
||
|
$this->assertNull($this->calendar->getGroup());
|
||
|
|
||
|
}
|
||
|
|
||
|
function testGetACL() {
|
||
|
|
||
|
$expected = array(
|
||
|
array(
|
||
|
'privilege' => '{DAV:}read',
|
||
|
'principal' => 'principals/user1',
|
||
|
'protected' => true,
|
||
|
),
|
||
|
array(
|
||
|
'privilege' => '{DAV:}write',
|
||
|
'principal' => 'principals/user1',
|
||
|
'protected' => true,
|
||
|
),
|
||
|
array(
|
||
|
'privilege' => '{DAV:}read',
|
||
|
'principal' => 'principals/user1/calendar-proxy-write',
|
||
|
'protected' => true,
|
||
|
),
|
||
|
array(
|
||
|
'privilege' => '{DAV:}write',
|
||
|
'principal' => 'principals/user1/calendar-proxy-write',
|
||
|
'protected' => true,
|
||
|
),
|
||
|
array(
|
||
|
'privilege' => '{DAV:}read',
|
||
|
'principal' => 'principals/user1/calendar-proxy-read',
|
||
|
'protected' => true,
|
||
|
),
|
||
|
array(
|
||
|
'privilege' => '{' . Sabre_CalDAV_Plugin::NS_CALDAV . '}read-free-busy',
|
||
|
'principal' => '{DAV:}authenticated',
|
||
|
'protected' => true,
|
||
|
),
|
||
|
);
|
||
|
$this->assertEquals($expected, $this->calendar->getACL());
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @expectedException Sabre_DAV_Exception_MethodNotAllowed
|
||
|
*/
|
||
|
function testSetACL() {
|
||
|
|
||
|
$this->calendar->setACL(array());
|
||
|
|
||
|
}
|
||
|
|
||
|
function testGetSupportedPrivilegesSet() {
|
||
|
|
||
|
$result = $this->calendar->getSupportedPrivilegeSet();
|
||
|
|
||
|
$this->assertEquals(
|
||
|
'{' . Sabre_CalDAV_Plugin::NS_CALDAV . '}read-free-busy',
|
||
|
$result['aggregates'][0]['aggregates'][2]['privilege']
|
||
|
);
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|