aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/sabre/dav/tests/Sabre/DAVServerTest.php
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/sabre/dav/tests/Sabre/DAVServerTest.php')
-rw-r--r--vendor/sabre/dav/tests/Sabre/DAVServerTest.php178
1 files changed, 178 insertions, 0 deletions
diff --git a/vendor/sabre/dav/tests/Sabre/DAVServerTest.php b/vendor/sabre/dav/tests/Sabre/DAVServerTest.php
new file mode 100644
index 000000000..a92c7065a
--- /dev/null
+++ b/vendor/sabre/dav/tests/Sabre/DAVServerTest.php
@@ -0,0 +1,178 @@
+<?php
+
+namespace Sabre;
+
+require_once 'Sabre/HTTP/ResponseMock.php';
+require_once 'Sabre/CalDAV/Backend/Mock.php';
+require_once 'Sabre/CardDAV/Backend/Mock.php';
+require_once 'Sabre/DAVACL/PrincipalBackend/Mock.php';
+require_once 'Sabre/DAV/Auth/Backend/Mock.php';
+
+/**
+ * This class may be used as a basis for other webdav-related unittests.
+ *
+ * This class is supposed to provide a reasonably big framework to quickly get
+ * a testing environment running.
+ *
+ * @copyright Copyright (C) 2007-2014 fruux GmbH (https://fruux.com/).
+ * @author Evert Pot (http://evertpot.com/)
+ * @license http://code.google.com/p/sabredav/wiki/License Modified BSD License
+ */
+abstract class DAVServerTest extends \PHPUnit_Framework_TestCase {
+
+ protected $setupCalDAV = false;
+ protected $setupCardDAV = false;
+ protected $setupACL = false;
+ protected $setupCalDAVSharing = false;
+
+ protected $caldavCalendars = array();
+ protected $caldavCalendarObjects = array();
+
+ protected $carddavAddressBooks = array();
+ protected $carddavCards = array();
+
+ /**
+ * @var Sabre\DAV\Server
+ */
+ protected $server;
+ protected $tree = array();
+
+ protected $caldavBackend;
+ protected $carddavBackend;
+ protected $principalBackend;
+
+ /**
+ * @var Sabre\CalDAV\Plugin
+ */
+ protected $caldavPlugin;
+
+ /**
+ * @var Sabre\CardDAV\Plugin
+ */
+ protected $carddavPlugin;
+
+ /**
+ * @var Sabre\DAVACL\Plugin
+ */
+ protected $aclPlugin;
+
+ /**
+ * @var Sabre\CalDAV\SharingPlugin
+ */
+ protected $caldavSharingPlugin;
+
+ /**
+ * @var Sabre\DAV\Auth\Plugin
+ */
+ protected $authPlugin;
+
+ /**
+ * If this string is set, we will automatically log in the user with this
+ * name.
+ */
+ protected $autoLogin = null;
+
+ function setUp() {
+
+ $this->setUpBackends();
+ $this->setUpTree();
+
+ $this->server = new DAV\Server($this->tree);
+ $this->server->debugExceptions = true;
+
+ if ($this->setupCalDAV) {
+ $this->caldavPlugin = new CalDAV\Plugin();
+ $this->server->addPlugin($this->caldavPlugin);
+ }
+ if ($this->setupCalDAVSharing) {
+ $this->caldavSharingPlugin = new CalDAV\SharingPlugin();
+ $this->server->addPlugin($this->caldavSharingPlugin);
+ }
+ if ($this->setupCardDAV) {
+ $this->carddavPlugin = new CardDAV\Plugin();
+ $this->server->addPlugin($this->carddavPlugin);
+ }
+ if ($this->setupACL) {
+ $this->aclPlugin = new DAVACL\Plugin();
+ $this->server->addPlugin($this->aclPlugin);
+ }
+ if ($this->autoLogin) {
+ $authBackend = new DAV\Auth\Backend\Mock();
+ $authBackend->defaultUser = $this->autoLogin;
+ $this->authPlugin = new DAV\Auth\Plugin($authBackend, 'SabreDAV');
+ $this->server->addPlugin($this->authPlugin);
+
+ // This will trigger the actual login procedure
+ $this->authPlugin->beforeMethod('OPTIONS','/');
+ }
+
+ }
+
+ /**
+ * Makes a request, and returns a response object.
+ *
+ * You can either pass an instance of Sabre\HTTP\Request, or an array,
+ * which will then be used as the _SERVER array.
+ *
+ * @param array|\Sabre\HTTP\Request $request
+ * @return \Sabre\HTTP\Response
+ */
+ function request($request) {
+
+ if (is_array($request)) {
+ $request = new HTTP\Request($request);
+ }
+ $this->server->httpRequest = $request;
+ $this->server->httpResponse = new HTTP\ResponseMock();
+ $this->server->exec();
+
+ return $this->server->httpResponse;
+
+ }
+
+ function setUpTree() {
+
+ if ($this->setupCalDAV) {
+ $this->tree[] = new CalDAV\CalendarRootNode(
+ $this->principalBackend,
+ $this->caldavBackend
+ );
+ }
+ if ($this->setupCardDAV) {
+ $this->tree[] = new CardDAV\AddressBookRoot(
+ $this->principalBackend,
+ $this->carddavBackend
+ );
+ }
+
+ if ($this->setupCardDAV || $this->setupCalDAV) {
+ $this->tree[] = new DAVACL\PrincipalCollection(
+ $this->principalBackend
+ );
+ }
+
+ }
+
+ function setUpBackends() {
+
+ if ($this->setupCalDAV && is_null($this->caldavBackend)) {
+ $this->caldavBackend = new CalDAV\Backend\Mock($this->caldavCalendars, $this->caldavCalendarObjects);
+ }
+ if ($this->setupCardDAV && is_null($this->carddavBackend)) {
+ $this->carddavBackend = new CardDAV\Backend\Mock($this->carddavAddressBooks, $this->carddavCards);
+ }
+ if ($this->setupCardDAV || $this->setupCalDAV) {
+ $this->principalBackend = new DAVACL\PrincipalBackend\Mock();
+ }
+
+ }
+
+
+ function assertHTTPStatus($expectedStatus, HTTP\Request $req) {
+
+ $resp = $this->request($req);
+ $this->assertEquals($resp->getStatusMessage($expectedStatus), $resp->status,'Incorrect HTTP status received: ' . $resp->body);
+
+ }
+
+}