All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.oracle.bedrock.testsupport.MavenProjectFileUtils Maven / Gradle / Ivy

package com.oracle.bedrock.testsupport;

import java.io.File;
import java.net.URISyntaxException;
import java.net.URL;
import java.nio.file.Files;
import java.util.stream.Stream;

import static org.junit.Assert.fail;

/**
 * A utility class to locate folders used during a Maven build.
 *
 * @author jk  2018.10.17
 */
public class MavenProjectFileUtils
{
    /**
     * This method is to locate the build folder.
     * 

* In a Maven build this will be the module's target folder. *

* If the project.build.directory System property is * set then that location will be returned otherwise the * {@link java.security.ProtectionDomain} of the specified * test class will be used to locate the build folder. * * @param classTest the test class to use to locate the build folder * @return the top level build folder. */ public static File locateBuildFolder(Class classTest) { String buildFolderProperty = System.getProperty("project.build.directory"); File buildFolder; if (buildFolderProperty == null || buildFolderProperty.trim().isEmpty()) { try { URL url = classTest.getProtectionDomain().getCodeSource().getLocation(); File file = new File(url.toURI()); while (!file.getName().equals("target")) { file = file.getParentFile(); } buildFolder = file; } catch (URISyntaxException e) { throw new RuntimeException(e); } } else { buildFolder = new File(buildFolderProperty); if (buildFolder.exists()) { if (!buildFolder.isDirectory()) { fail("The project.build.directory property is not a directory: " + buildFolderProperty); } } else { fail("The project.build.directory property was set to a non-existent folder: " + buildFolderProperty); } } return buildFolder; } /** * Locate the base folder to use for test output logs for the specified test class. *

* By default for a Maven build this will be target/test-output/functional. * * @param classTest the test class being executed * @return the location to put test logs */ public static File ensureTestOutputBaseFolder(Class classTest) { File fileBuild = ensureFolders(locateBuildFolder(classTest)); File fileTestOut = ensureFolders(new File(fileBuild, "test-output")); return ensureFolders(new File(fileTestOut, "functional")); } /** * Locate the folder to use for test output logs for the specified test class. *

* By default for a Maven build this will be target/test-output/functional/class-name. * * @param classTest the test class being executed * @return the location to put test logs */ public static File ensureTestOutputFolder(Class classTest, String sSuffix) { File fileBuild = ensureFolders(locateBuildFolder(classTest)); File fileTestOut = ensureFolders(new File(fileBuild, "test-output")); File fileTestOutFunctional = ensureFolders(new File(fileTestOut, "functional")); File fileTest = new File(fileTestOutFunctional, classTest.getSimpleName()); if (sSuffix != null && !sSuffix.trim().isEmpty()) { fileTest = new File(fileTest, sSuffix); } return ensureFolders(fileTest); } private static File ensureFolders(File file) { if (!file.exists()) { file.mkdirs(); } return file; } /** * Recursively delete the specified folder. * * @param folder the folder to delete */ public static void recursiveDelete(File folder) { File[] files = folder.listFiles(); if (files != null) { for (File each : files) { recursiveDelete(each); } } folder.delete(); } /** * Determine if a file contains any line matching the * specified regex. * * @param file the file to search * @param regex the regular expression to look for * @return {@code true} if the file contains a line matching * the regular expression */ public static boolean fileContains(File file, String regex) { try { Stream stream = Files.lines(file.toPath()); return stream.anyMatch(s -> s.matches(regex)); } catch (Exception e) { e.printStackTrace(); fail("There was an error while reading the file" + file); } return false; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy