/*
* 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.apache.jackrabbit.core.data;
import java.io.File;
import java.io.FileOutputStream;
import java.util.Properties;
import javax.jcr.RepositoryException;
import org.apache.commons.io.IOUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class TestCachingFDS extends TestFileDataStore {
protected static final Logger LOG = LoggerFactory.getLogger(TestCachingFDS.class);
private static final String PENDIND_UPLOAD_FILE = "async-pending-uploads.ser";
private static final String TO_BE_DELETED_UPLOAD_FILE = "async-tobedeleted-uploads.ser";
protected DataStore createDataStore() throws RepositoryException {
CachingFDS cacheFDS = new CachingFDS();
Properties props = loadProperties("/fs.properties");
String pathValue = props.getProperty(FSBackend.FS_BACKEND_PATH);
if (pathValue != null && !"".equals(pathValue.trim())) {
fsPath = pathValue + "/cachingFds" + "-"
+ String.valueOf(randomGen.nextInt(100000)) + "-"
+ String.valueOf(randomGen.nextInt(100000));
} else {
fsPath = dataStoreDir + "/cachingFds";
}
props.setProperty(FSBackend.FS_BACKEND_PATH, fsPath);
LOG.info("fsBackendPath [{}] set.", fsPath);
cacheFDS.setProperties(props);
cacheFDS.setSecret("12345");
// disable asynchronous writing in testing.
cacheFDS.setAsyncUploadLimit(0);
cacheFDS.init(dataStoreDir);
return cacheFDS;
}
/**
* Test robustness of {@link AsyncUploadCache} corruption.
*/
public void testAsyncUploadCacheCorruption() {
try {
ds = createDataStore();
File pendingUploads = new File(dataStoreDir + "/"
+ PENDIND_UPLOAD_FILE);
FileOutputStream fos = new FileOutputStream(pendingUploads);
IOUtils.write("garbage-data", fos);
fos.close();
File tobeDeletedFile = new File(dataStoreDir + "/"
+ TO_BE_DELETED_UPLOAD_FILE);
fos = new FileOutputStream(tobeDeletedFile);
IOUtils.write("garbage-data", fos);
fos.close();
ds.close();
doAddRecordTest();
} catch (Exception e) {
LOG.error("error:", e);
fail(e.getMessage());
}
}
}