blob: 45f88d0193d5d439d8ff3aa76bfc5d67fe722d91 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.jclouds.filesystem.integration;
import static org.jclouds.blobstore.options.ListContainerOptions.Builder.maxResults;
import static org.jclouds.filesystem.util.Utils.isMacOSX;
import static org.testng.Assert.assertEquals;
import static org.jclouds.utils.TestUtils.NO_INVOCATIONS;
import static org.jclouds.utils.TestUtils.SINGLE_NO_ARG_INVOCATION;
import java.io.IOException;
import java.util.Properties;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.TimeoutException;
import javax.ws.rs.core.MediaType;
import com.google.common.collect.ImmutableSet;
import org.jclouds.blobstore.domain.Blob;
import org.jclouds.blobstore.domain.BlobMetadata;
import org.jclouds.blobstore.domain.PageSet;
import org.jclouds.blobstore.domain.StorageMetadata;
import org.jclouds.blobstore.integration.internal.BaseBlobStoreIntegrationTest;
import org.jclouds.blobstore.integration.internal.BaseContainerIntegrationTest;
import org.jclouds.filesystem.reference.FilesystemConstants;
import org.jclouds.filesystem.utils.TestUtils;
import org.testng.SkipException;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.Iterables;
@Test(groups = { "integration", "live" }, testName = "blobstore.FilesystemContainerIntegrationTest")
public class FilesystemContainerIntegrationTest extends BaseContainerIntegrationTest {
public FilesystemContainerIntegrationTest() {
provider = "filesystem";
BaseBlobStoreIntegrationTest.SANITY_CHECK_RETURNED_BUCKET_NAME = true;
}
@Override
protected Properties setupProperties() {
Properties props = super.setupProperties();
props.setProperty(FilesystemConstants.PROPERTY_BASEDIR, TestUtils.TARGET_BASE_DIR);
return props;
}
@Test(dataProvider = "ignoreOnWindows", groups = { "integration", "live" })
public void testNotWithDetails() throws InterruptedException {
String key = "hello";
// NOTE all metadata in jclouds comes out as lowercase, in an effort to
// normalize the
// providers.
Blob object = view.getBlobStore().blobBuilder(key).userMetadata(ImmutableMap.of("Adrian", "powderpuff"))
.payload(TEST_STRING).contentType(MediaType.TEXT_PLAIN).build();
String containerName = getContainerName();
try {
addBlobToContainer(containerName, object);
validateContent(containerName, key);
PageSet<? extends StorageMetadata> container = view.getBlobStore().list(containerName, maxResults(1));
BlobMetadata metadata = (BlobMetadata) Iterables.getOnlyElement(container);
// transient container should be lenient and not return metadata on
// undetailed listing.
assertEquals(metadata.getUserMetadata().size(), 0);
} finally {
returnContainer(containerName);
}
}
// Mac OS X HFS+ does not support UserDefinedFileAttributeView:
// https://bugs.openjdk.java.net/browse/JDK-8030048
@Test(dataProvider = "ignoreOnMacOSX")
@Override
public void testWithDetails() throws InterruptedException, IOException {
super.testWithDetails();
}
@Override
@Test(dataProvider = "ignoreOnWindows")
public void containerExists() throws InterruptedException {
super.containerExists();
}
@Override
@Test(dataProvider = "ignoreOnWindows")
public void deleteContainerWithContents() throws InterruptedException {
super.deleteContainerWithContents();
}
@Override
@Test(dataProvider = "ignoreOnWindows")
public void deleteContainerWithoutContents() throws InterruptedException {
super.deleteContainerWithoutContents();
}
@Override
@Test(dataProvider = "ignoreOnWindows")
public void deleteContainerIfEmptyWithContents() throws InterruptedException {
super.deleteContainerIfEmptyWithContents();
}
@Override
@Test(dataProvider = "ignoreOnWindows")
public void deleteContainerIfEmptyWithoutContents() throws InterruptedException {
super.deleteContainerIfEmptyWithoutContents();
}
@Override
@Test(dataProvider = "ignoreOnWindows")
public void testListContainer() throws InterruptedException, ExecutionException, TimeoutException {
super.testListContainer();
}
@Override
@Test(dataProvider = "ignoreOnWindows")
public void testListContainerMarker() throws InterruptedException {
super.testListContainerMarker();
}
@Override
@Test(dataProvider = "ignoreOnWindows")
public void testListContainerPrefix() throws InterruptedException {
super.testListContainerPrefix();
}
@Override
@Test(dataProvider = "ignoreOnWindows")
public void testListRootUsesDelimiter() throws InterruptedException {
super.testListRootUsesDelimiter();
}
@Override
@Test(dataProvider = "ignoreOnWindows")
public void testPutTwiceIsOkAndDoesntOverwrite() throws InterruptedException {
super.testPutTwiceIsOkAndDoesntOverwrite();
}
@Override
@Test(dataProvider = "ignoreOnWindows")
public void testListContainerMaxResults() throws InterruptedException {
super.testListContainerMaxResults();
}
@Override
public void testDirectory() {
throw new SkipException("There is no notion of marker blobs in the file system blob store");
}
@DataProvider
public Object[][] ignoreOnMacOSX() {
return isMacOSX() ? NO_INVOCATIONS
: SINGLE_NO_ARG_INVOCATION;
}
@DataProvider
public Object[][] ignoreOnWindows() {
return TestUtils.isWindowsOs() ? NO_INVOCATIONS
: SINGLE_NO_ARG_INVOCATION;
}
@Override
@DataProvider
public Object[][] getBlobsToEscape() {
if (TestUtils.isWindowsOs()) {
Object[][] result = new Object[1][1];
result[0][0] = ImmutableSet.of("%20", " %20");
return result;
}
return super.getBlobsToEscape();
}
@Override
@Test(groups = { "integration", "live" })
public void testSetContainerAccess() throws Exception {
throw new SkipException("filesystem does not support anonymous access");
}
}