aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/sabre/dav/tests/Sabre/CalDAV/ValidateICalTest.php
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/sabre/dav/tests/Sabre/CalDAV/ValidateICalTest.php')
-rw-r--r--vendor/sabre/dav/tests/Sabre/CalDAV/ValidateICalTest.php392
1 files changed, 0 insertions, 392 deletions
diff --git a/vendor/sabre/dav/tests/Sabre/CalDAV/ValidateICalTest.php b/vendor/sabre/dav/tests/Sabre/CalDAV/ValidateICalTest.php
deleted file mode 100644
index 4e2411391..000000000
--- a/vendor/sabre/dav/tests/Sabre/CalDAV/ValidateICalTest.php
+++ /dev/null
@@ -1,392 +0,0 @@
-<?php
-
-declare(strict_types=1);
-
-namespace Sabre\CalDAV;
-
-use Sabre\DAV;
-use Sabre\DAVACL;
-use Sabre\HTTP;
-
-class ValidateICalTest extends \PHPUnit\Framework\TestCase
-{
- /**
- * @var DAV\Server
- */
- protected $server;
- /**
- * @var Sabre\CalDAV\Backend\Mock
- */
- protected $calBackend;
-
- public function setup(): void
- {
- $calendars = [
- [
- 'id' => 'calendar1',
- 'principaluri' => 'principals/admin',
- 'uri' => 'calendar1',
- '{urn:ietf:params:xml:ns:caldav}supported-calendar-component-set' => new Xml\Property\SupportedCalendarComponentSet(['VEVENT', 'VTODO', 'VJOURNAL']),
- ],
- [
- 'id' => 'calendar2',
- 'principaluri' => 'principals/admin',
- 'uri' => 'calendar2',
- '{urn:ietf:params:xml:ns:caldav}supported-calendar-component-set' => new Xml\Property\SupportedCalendarComponentSet(['VTODO', 'VJOURNAL']),
- ],
- ];
-
- $this->calBackend = new Backend\Mock($calendars, []);
- $principalBackend = new DAVACL\PrincipalBackend\Mock();
-
- $tree = [
- new CalendarRoot($principalBackend, $this->calBackend),
- ];
-
- $this->server = new DAV\Server($tree);
- $this->server->sapi = new HTTP\SapiMock();
- $this->server->debugExceptions = true;
-
- $plugin = new Plugin();
- $this->server->addPlugin($plugin);
-
- $response = new HTTP\ResponseMock();
- $this->server->httpResponse = $response;
- }
-
- /**
- * @return Sabre\HTTP\ResponseMock
- */
- public function request(HTTP\Request $request)
- {
- $this->server->httpRequest = $request;
- $this->server->exec();
-
- return $this->server->httpResponse;
- }
-
- public function testCreateFile()
- {
- $request = HTTP\Sapi::createFromServerArray([
- 'REQUEST_METHOD' => 'PUT',
- 'REQUEST_URI' => '/calendars/admin/calendar1/blabla.ics',
- ]);
-
- $response = $this->request($request);
-
- $this->assertEquals(415, $response->status);
- }
-
- public function testCreateFileValid()
- {
- $request = new HTTP\Request(
- 'PUT',
- '/calendars/admin/calendar1/blabla.ics',
- ['Prefer' => 'handling=strict']
- );
-
- $ics = <<<ICS
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:foo
-BEGIN:VEVENT
-UID:foo
-DTSTAMP:20160406T052348Z
-DTSTART:20160706T140000Z
-END:VEVENT
-END:VCALENDAR
-ICS;
-
- $request->setBody($ics);
-
- $response = $this->request($request);
-
- $this->assertEquals(201, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- $this->assertEquals([
- 'X-Sabre-Version' => [DAV\Version::VERSION],
- 'Content-Length' => ['0'],
- 'ETag' => ['"'.md5($ics).'"'],
- ], $response->getHeaders());
-
- $expected = [
- 'uri' => 'blabla.ics',
- 'calendardata' => $ics,
- 'calendarid' => 'calendar1',
- 'lastmodified' => null,
- ];
-
- $this->assertEquals($expected, $this->calBackend->getCalendarObject('calendar1', 'blabla.ics'));
- }
-
- public function testCreateFileNoVersion()
- {
- $request = new HTTP\Request(
- 'PUT',
- '/calendars/admin/calendar1/blabla.ics',
- ['Prefer' => 'handling=strict']
- );
-
- $ics = <<<ICS
-BEGIN:VCALENDAR
-PRODID:foo
-BEGIN:VEVENT
-UID:foo
-DTSTAMP:20160406T052348Z
-DTSTART:20160706T140000Z
-END:VEVENT
-END:VCALENDAR
-ICS;
-
- $request->setBody($ics);
-
- $response = $this->request($request);
-
- $this->assertEquals(415, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- }
-
- public function testCreateFileNoVersionFixed()
- {
- $request = new HTTP\Request(
- 'PUT',
- '/calendars/admin/calendar1/blabla.ics',
- ['Prefer' => 'handling=lenient']
- );
-
- $ics = <<<ICS
-BEGIN:VCALENDAR
-PRODID:foo
-BEGIN:VEVENT
-UID:foo
-DTSTAMP:20160406T052348Z
-DTSTART:20160706T140000Z
-END:VEVENT
-END:VCALENDAR
-ICS;
-
- $request->setBody($ics);
-
- $response = $this->request($request);
-
- $this->assertEquals(201, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- $this->assertEquals([
- 'X-Sabre-Version' => [DAV\Version::VERSION],
- 'Content-Length' => ['0'],
- 'X-Sabre-Ew-Gross' => ['iCalendar validation warning: VERSION MUST appear exactly once in a VCALENDAR component'],
- ], $response->getHeaders());
-
- $ics = <<<ICS
-BEGIN:VCALENDAR\r
-VERSION:2.0\r
-PRODID:foo\r
-BEGIN:VEVENT\r
-UID:foo\r
-DTSTAMP:20160406T052348Z\r
-DTSTART:20160706T140000Z\r
-END:VEVENT\r
-END:VCALENDAR\r
-
-ICS;
-
- $expected = [
- 'uri' => 'blabla.ics',
- 'calendardata' => $ics,
- 'calendarid' => 'calendar1',
- 'lastmodified' => null,
- ];
-
- $this->assertEquals($expected, $this->calBackend->getCalendarObject('calendar1', 'blabla.ics'));
- }
-
- public function testCreateFileNoComponents()
- {
- $request = new HTTP\Request(
- 'PUT',
- '/calendars/admin/calendar1/blabla.ics',
- ['Prefer' => 'handling=strict']
- );
- $ics = <<<ICS
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:foo
-END:VCALENDAR
-ICS;
-
- $request->setBody($ics);
-
- $response = $this->request($request);
- $this->assertEquals(403, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- }
-
- public function testCreateFileNoUID()
- {
- $request = HTTP\Sapi::createFromServerArray([
- 'REQUEST_METHOD' => 'PUT',
- 'REQUEST_URI' => '/calendars/admin/calendar1/blabla.ics',
- ]);
- $request->setBody("BEGIN:VCALENDAR\r\nBEGIN:VEVENT\r\nEND:VEVENT\r\nEND:VCALENDAR\r\n");
-
- $response = $this->request($request);
-
- $this->assertEquals(415, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- }
-
- public function testCreateFileVCard()
- {
- $request = HTTP\Sapi::createFromServerArray([
- 'REQUEST_METHOD' => 'PUT',
- 'REQUEST_URI' => '/calendars/admin/calendar1/blabla.ics',
- ]);
- $request->setBody("BEGIN:VCARD\r\nEND:VCARD\r\n");
-
- $response = $this->request($request);
-
- $this->assertEquals(415, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- }
-
- public function testCreateFile2Components()
- {
- $request = HTTP\Sapi::createFromServerArray([
- 'REQUEST_METHOD' => 'PUT',
- 'REQUEST_URI' => '/calendars/admin/calendar1/blabla.ics',
- ]);
- $request->setBody("BEGIN:VCALENDAR\r\nBEGIN:VEVENT\r\nUID:foo\r\nEND:VEVENT\r\nBEGIN:VJOURNAL\r\nUID:foo\r\nEND:VJOURNAL\r\nEND:VCALENDAR\r\n");
-
- $response = $this->request($request);
-
- $this->assertEquals(415, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- }
-
- public function testCreateFile2UIDS()
- {
- $request = HTTP\Sapi::createFromServerArray([
- 'REQUEST_METHOD' => 'PUT',
- 'REQUEST_URI' => '/calendars/admin/calendar1/blabla.ics',
- ]);
- $request->setBody("BEGIN:VCALENDAR\r\nBEGIN:VTIMEZONE\r\nEND:VTIMEZONE\r\nBEGIN:VEVENT\r\nUID:foo\r\nEND:VEVENT\r\nBEGIN:VEVENT\r\nUID:bar\r\nEND:VEVENT\r\nEND:VCALENDAR\r\n");
-
- $response = $this->request($request);
-
- $this->assertEquals(415, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- }
-
- public function testCreateFileWrongComponent()
- {
- $request = HTTP\Sapi::createFromServerArray([
- 'REQUEST_METHOD' => 'PUT',
- 'REQUEST_URI' => '/calendars/admin/calendar1/blabla.ics',
- ]);
- $request->setBody("BEGIN:VCALENDAR\r\nBEGIN:VTIMEZONE\r\nEND:VTIMEZONE\r\nBEGIN:VFREEBUSY\r\nUID:foo\r\nEND:VFREEBUSY\r\nEND:VCALENDAR\r\n");
-
- $response = $this->request($request);
-
- $this->assertEquals(403, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- }
-
- public function testUpdateFile()
- {
- $this->calBackend->createCalendarObject('calendar1', 'blabla.ics', 'foo');
- $request = HTTP\Sapi::createFromServerArray([
- 'REQUEST_METHOD' => 'PUT',
- 'REQUEST_URI' => '/calendars/admin/calendar1/blabla.ics',
- ]);
-
- $response = $this->request($request);
-
- $this->assertEquals(415, $response->status);
- }
-
- public function testUpdateFileParsableBody()
- {
- $this->calBackend->createCalendarObject('calendar1', 'blabla.ics', 'foo');
- $request = new HTTP\Request(
- 'PUT',
- '/calendars/admin/calendar1/blabla.ics'
- );
- $ics = <<<ICS
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:foo
-BEGIN:VEVENT
-UID:foo
-DTSTAMP:20160406T052348Z
-DTSTART:20160706T140000Z
-END:VEVENT
-END:VCALENDAR
-ICS;
-
- $request->setBody($ics);
- $response = $this->request($request);
-
- $this->assertEquals(204, $response->status);
-
- $expected = [
- 'uri' => 'blabla.ics',
- 'calendardata' => $ics,
- 'calendarid' => 'calendar1',
- 'lastmodified' => null,
- ];
-
- $this->assertEquals($expected, $this->calBackend->getCalendarObject('calendar1', 'blabla.ics'));
- }
-
- public function testCreateFileInvalidComponent()
- {
- $request = HTTP\Sapi::createFromServerArray([
- 'REQUEST_METHOD' => 'PUT',
- 'REQUEST_URI' => '/calendars/admin/calendar2/blabla.ics',
- ]);
- $request->setBody("BEGIN:VCALENDAR\r\nBEGIN:VTIMEZONE\r\nEND:VTIMEZONE\r\nBEGIN:VEVENT\r\nUID:foo\r\nEND:VEVENT\r\nEND:VCALENDAR\r\n");
-
- $response = $this->request($request);
-
- $this->assertEquals(403, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- }
-
- public function testUpdateFileInvalidComponent()
- {
- $this->calBackend->createCalendarObject('calendar2', 'blabla.ics', 'foo');
- $request = HTTP\Sapi::createFromServerArray([
- 'REQUEST_METHOD' => 'PUT',
- 'REQUEST_URI' => '/calendars/admin/calendar2/blabla.ics',
- ]);
- $request->setBody("BEGIN:VCALENDAR\r\nBEGIN:VTIMEZONE\r\nEND:VTIMEZONE\r\nBEGIN:VEVENT\r\nUID:foo\r\nEND:VEVENT\r\nEND:VCALENDAR\r\n");
-
- $response = $this->request($request);
-
- $this->assertEquals(403, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- }
-
- /**
- * What we are testing here, is if we send in a latin1 character, the
- * server should automatically transform this into UTF-8.
- *
- * More importantly. If any transformation happens, the etag must no longer
- * be returned by the server.
- */
- public function testCreateFileModified()
- {
- $request = new HTTP\Request(
- 'PUT',
- '/calendars/admin/calendar1/blabla.ics'
- );
- $ics = <<<ICS
-BEGIN:VCALENDAR
-VERSION:2.0
-PRODID:foo
-BEGIN:VEVENT
-UID:foo
-SUMMARY:Meeting in M\xfcnster
-DTSTAMP:20160406T052348Z
-DTSTART:20160706T140000Z
-END:VEVENT
-END:VCALENDAR
-ICS;
-
- $request->setBody($ics);
-
- $response = $this->request($request);
-
- $this->assertEquals(201, $response->status, 'Incorrect status returned! Full response body: '.$response->getBodyAsString());
- $this->assertNull($response->getHeader('ETag'));
- }
-}