mirror of
https://github.com/etesync/android
synced 2025-07-14 18:48:24 +00:00

This commit includes the major changes between DAVdroid and EteSync. It adjusts the app to use the EteSync protocol and server. It includes some ugliness still, and it's a squash of many ugly snapshot commits while hacking on the initial DAVdroid code. History should be "clean" from this point onwards.
128 lines
4.6 KiB
Java
128 lines
4.6 KiB
Java
/*
|
||
* Copyright © 2013 – 2016 Ricki Hirner (bitfire web engineering).
|
||
* All rights reserved. This program and the accompanying materials
|
||
* are made available under the terms of the GNU Public License v3.0
|
||
* which accompanies this distribution, and is available at
|
||
* http://www.gnu.org/licenses/gpl.html
|
||
*/
|
||
|
||
package at.bitfire.davdroid.ui.setup;
|
||
|
||
import org.junit.After;
|
||
import org.junit.Before;
|
||
|
||
import java.net.URI;
|
||
|
||
import at.bitfire.davdroid.App;
|
||
import at.bitfire.davdroid.HttpClient;
|
||
import okhttp3.OkHttpClient;
|
||
import okhttp3.mockwebserver.Dispatcher;
|
||
import okhttp3.mockwebserver.MockResponse;
|
||
import okhttp3.mockwebserver.MockWebServer;
|
||
import okhttp3.mockwebserver.RecordedRequest;
|
||
|
||
import static android.support.test.InstrumentationRegistry.getTargetContext;
|
||
|
||
public class DavResourceFinderTest {
|
||
|
||
MockWebServer server = new MockWebServer();
|
||
|
||
DavResourceFinder finder;
|
||
OkHttpClient client;
|
||
LoginCredentials credentials;
|
||
|
||
private static final String
|
||
PATH_NO_DAV = "/nodav",
|
||
|
||
PATH_CALDAV = "/caldav",
|
||
PATH_CARDDAV = "/carddav",
|
||
PATH_CALDAV_AND_CARDDAV = "/both-caldav-carddav",
|
||
|
||
SUBPATH_PRINCIPAL = "/principal",
|
||
SUBPATH_ADDRESSBOOK_HOMESET = "/addressbooks",
|
||
SUBPATH_ADDRESSBOOK = "/addressbooks/private-contacts";
|
||
|
||
@Before
|
||
public void initServerAndClient() throws Exception {
|
||
server.setDispatcher(new TestDispatcher());
|
||
server.start();
|
||
|
||
credentials = new LoginCredentials(URI.create("/"), "mock", "12345");
|
||
finder = new DavResourceFinder(getTargetContext(), credentials);
|
||
|
||
client = HttpClient.create(null);
|
||
}
|
||
|
||
@After
|
||
public void stopServer() throws Exception {
|
||
server.shutdown();
|
||
}
|
||
|
||
// mock server
|
||
|
||
public class TestDispatcher extends Dispatcher {
|
||
|
||
@Override
|
||
public MockResponse dispatch(RecordedRequest rq) throws InterruptedException {
|
||
if (!checkAuth(rq)) {
|
||
MockResponse authenticate = new MockResponse().setResponseCode(401);
|
||
authenticate.setHeader("WWW-Authenticate", "Basic realm=\"test\"");
|
||
return authenticate;
|
||
}
|
||
|
||
String path = rq.getPath();
|
||
|
||
if ("OPTIONS".equalsIgnoreCase(rq.getMethod())) {
|
||
String dav = null;
|
||
if (path.startsWith(PATH_CALDAV))
|
||
dav = "calendar-access";
|
||
else if (path.startsWith(PATH_CARDDAV))
|
||
dav = "addressbook";
|
||
else if (path.startsWith(PATH_CALDAV_AND_CARDDAV))
|
||
dav = "calendar-access, addressbook";
|
||
MockResponse response = new MockResponse().setResponseCode(200);
|
||
if (dav != null)
|
||
response.addHeader("DAV", dav);
|
||
return response;
|
||
|
||
} else if ("PROPFIND".equalsIgnoreCase(rq.getMethod())) {
|
||
String props = null;
|
||
switch (path) {
|
||
case PATH_CALDAV:
|
||
case PATH_CARDDAV:
|
||
props = "<current-user-principal><href>" + path + SUBPATH_PRINCIPAL + "</href></current-user-principal>";
|
||
break;
|
||
|
||
case PATH_CARDDAV + SUBPATH_PRINCIPAL:
|
||
props = "<CARD:addressbook-home-set>" +
|
||
" <href>" + PATH_CARDDAV + SUBPATH_ADDRESSBOOK_HOMESET + "</href>" +
|
||
"</CARD:addressbook-home-set>";
|
||
break;
|
||
case PATH_CARDDAV + SUBPATH_ADDRESSBOOK:
|
||
props = "<resourcetype>" +
|
||
" <collection/>" +
|
||
" <CARD:addressbook/>" +
|
||
"</resourcetype>";
|
||
break;
|
||
}
|
||
App.log.info("Sending props: " + props);
|
||
return new MockResponse()
|
||
.setResponseCode(207)
|
||
.setBody("<multistatus xmlns='DAV:' xmlns:CARD='urn:ietf:params:xml:ns:carddav'>" +
|
||
"<response>" +
|
||
" <href>" + rq.getPath() + "</href>" +
|
||
" <propstat><prop>" + props + "</prop></propstat>" +
|
||
"</response>" +
|
||
"</multistatus>");
|
||
}
|
||
|
||
return new MockResponse().setResponseCode(404);
|
||
}
|
||
|
||
private boolean checkAuth(RecordedRequest rq) {
|
||
return "Basic bW9jazoxMjM0NQ==".equals(rq.getHeader("Authorization"));
|
||
}
|
||
}
|
||
|
||
}
|