blob: 9264d7d8dc3d2784f30eb8a51cabd537e2ace173 [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.apache.logging.log4j.test.junit;
import java.io.File;
import java.io.IOException;
import java.io.PrintStream;
import java.nio.file.FileVisitResult;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.SimpleFileVisitor;
import java.nio.file.attribute.BasicFileAttributes;
import org.apache.logging.log4j.test.junit.AbstractExternalFileCleaner;
/**
* A JUnit test rule to automatically delete folders recursively before
* (optional) and after (optional) a test is run.
* <p>
* This class should not perform logging using Log4j to avoid accidentally
* loading or re-loading Log4j configurations.
* </p>
*/
public class CleanFolders extends AbstractExternalFileCleaner {
public static final class DeleteAllFileVisitor extends SimpleFileVisitor<Path> {
private final PrintStream printStream;
public DeleteAllFileVisitor(final PrintStream logger) {
this.printStream = logger;
}
@Override
public FileVisitResult postVisitDirectory(final Path dir, final IOException exc) throws IOException {
printf("%s Deleting directory %s\n", CLEANER_MARKER, dir);
final boolean deleted = Files.deleteIfExists(dir);
printf("%s Deleted directory %s: %s\n", CLEANER_MARKER, dir, deleted);
return FileVisitResult.CONTINUE;
}
protected void printf(final String format, final Object... args) {
if (printStream != null) {
printStream.printf(format, args);
}
}
@Override
public FileVisitResult visitFile(final Path file, final BasicFileAttributes attrs) throws IOException {
printf("%s Deleting file %s with %s\n", CLEANER_MARKER, file, attrs);
final boolean deleted = Files.deleteIfExists(file);
printf(CLEANER_MARKER, "%s Deleted file %s: %s\n", file, deleted);
return FileVisitResult.CONTINUE;
}
}
private static final int MAX_TRIES = 10;
public CleanFolders(final boolean before, final boolean after, final int maxTries, final File... files) {
super(before, after, maxTries, null, files);
}
public CleanFolders(final boolean before, final boolean after, final int maxTries, final Path... paths) {
super(before, after, maxTries, null, paths);
}
public CleanFolders(final boolean before, final boolean after, final int maxTries, final String... fileNames) {
super(before, after, maxTries, null, fileNames);
}
public CleanFolders(final File... folders) {
super(true, true, MAX_TRIES, null, folders);
}
public CleanFolders(final Path... paths) {
super(true, true, MAX_TRIES, null, paths);
}
public CleanFolders(final PrintStream logger, final File... folders) {
super(true, true, MAX_TRIES, logger, folders);
}
public CleanFolders(final String... folderNames) {
super(true, true, MAX_TRIES, null, folderNames);
}
@Override
protected boolean clean(final Path path, final int tryIndex) throws IOException {
cleanFolder(path, tryIndex);
return true;
}
private void cleanFolder(final Path folder, final int tryIndex) throws IOException {
if (Files.exists(folder) && Files.isDirectory(folder)) {
Files.walkFileTree(folder, new DeleteAllFileVisitor(getPrintStream()));
}
}
}