/*
* Copyright (C) 2009 eXo Platform SAS.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.exoplatform.services.jcr.webdav.command;
import org.exoplatform.common.http.HTTPStatus;
import org.exoplatform.services.jcr.webdav.BaseStandaloneTest;
import org.exoplatform.services.jcr.webdav.WebDavConstants.WebDAVMethods;
import org.exoplatform.services.jcr.webdav.WebDavServiceImpl;
import org.exoplatform.services.jcr.webdav.util.TextUtil;
import org.exoplatform.services.jcr.webdav.utils.TestUtils;
import org.exoplatform.services.rest.ExtHttpHeaders;
import org.exoplatform.services.rest.impl.ContainerResponse;
import org.exoplatform.services.rest.impl.MultivaluedMapImpl;
import java.io.ByteArrayInputStream;
import javax.jcr.Node;
import javax.ws.rs.core.MultivaluedMap;
/**
* Created by The eXo Platform SAS Author : Dmytro Katayev
* work.visor.ck@gmail.com Aug 13, 2008
*/
public class TestMkCol extends BaseStandaloneTest
{
public void testSimpleMkCol() throws Exception
{
String folder = TestUtils.getFolderName();
ContainerResponse response = service(WebDAVMethods.MKCOL, getPathWS() + folder, "", null, null);
assertEquals(HTTPStatus.CREATED, response.getStatus());
response = serviceWithEscape(WebDAVMethods.MKCOL, getPathWS() + folder + "[2]", "", null, null);
assertEquals(HTTPStatus.CREATED, response.getStatus());
}
public void testSimpleMkColWithFakePathWS() throws Exception
{
String folder = TestUtils.getFolderName();
ContainerResponse response = service(WebDAVMethods.MKCOL, getFakePathWS() + folder, "", null, null);
assertEquals(HTTPStatus.CREATED, response.getStatus());
}
public void testMkCol() throws Exception
{
String folder = TestUtils.getFolderName();
ContainerResponse response = service(WebDAVMethods.MKCOL, getPathWS() + folder, "", null, null);
assertEquals(HTTPStatus.CREATED, response.getStatus());
String file = TestUtils.getFileName();
String path = folder + file;
String content = TestUtils.getFileContent();
ByteArrayInputStream inputStream = new ByteArrayInputStream(content.getBytes());
TestUtils.addContent(session, path, inputStream, defaultFileNodeType, "");
assertTrue(session.getRootNode().hasNode(TextUtil.relativizePath(folder)));
Node folderNode = session.getRootNode().getNode(TextUtil.relativizePath(folder));
assertTrue(folderNode.hasNode(TextUtil.relativizePath(file)));
}
public void testFolderNodeTypeHeader() throws Exception
{
String folder = TestUtils.getFolderName();
MultivaluedMap<String, String> headers = new MultivaluedMapImpl();
headers.add(ExtHttpHeaders.FOLDER_NODETYPE, "nt:file");
ContainerResponse response = service(WebDAVMethods.MKCOL, getPathWS() + folder, "", headers, null);
assertEquals(HTTPStatus.UNSUPPORTED_TYPE, response.getStatus());
headers.clear();
headers.add(ExtHttpHeaders.FILE_NODETYPE, "nt:folder");
response = service(WebDAVMethods.MKCOL, getPathWS() + folder, "", headers, null);
assertEquals(HTTPStatus.CREATED, response.getStatus());
}
/**
* Testing {@link WebDavServiceImpl} MKCOL method for correct response
* building. According to 'RFC-2616' it is expected to contain 'location' header.
* More info is introduced <a href=http://tools.ietf.org/html/rfc2616#section-14.30>here</a>.
* @throws Exception
*/
public void testLocationHeaderInMkColResponse() throws Exception
{
String folder = TestUtils.getFolderName();
// execute query
ContainerResponse response = service(WebDAVMethods.MKCOL, getPathWS() + folder, "", null, null);
// check if operation completed successfully, we expect a new resource to be created
assertEquals(HTTPStatus.CREATED, response.getStatus());
// here we check if response 'CREATED' contains 'LOCATION' header
assertTrue(response.getHttpHeaders().containsKey(ExtHttpHeaders.LOCATION));
// here we check if 'CREATED' response 'LOCATION' header contains correct location path
assertEquals(getPathWS() + folder, response.getHttpHeaders().getFirst(ExtHttpHeaders.LOCATION).toString());
}
/**
* Here we're testing the case when we are trying to create a collection B at a path /A/B
* and a A collection does not exist. According to the <a href=http://www.webdav.org/specs/rfc4918.html#rfc.section.9.3.1>
* RFC 4918</a> section we are to receive 409(conflict) HTTP status.
* @throws Exception
*/
public void testMkColInNonExistingWorkspace() throws Exception
{
String folder = TestUtils.getFolderName();
ContainerResponse response = service(WebDAVMethods.MKCOL, getPathWS() + "_" + folder, "", null, null);
assertEquals(HTTPStatus.CONFLICT, response.getStatus());
}
public void testConflict() throws Exception
{
String folder = TestUtils.getFolderName();
ContainerResponse response = service(WebDAVMethods.MKCOL, getPathWS() + folder + folder, "", null, null);
assertEquals(HTTPStatus.CONFLICT, response.getStatus());
}
@Override
protected String getRepositoryName()
{
return null;
}
}