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

com.slickqa.jupiter.BeforeEachExtension Maven / Gradle / Ivy

package com.slickqa.jupiter;

import com.slickqa.client.errors.SlickError;
import com.slickqa.client.model.Result;
import com.slickqa.client.model.Testrun;
import com.slickqa.jupiter.parameterized.ArgumentsChecksumStore;
import org.junit.jupiter.api.extension.BeforeEachCallback;
import org.junit.jupiter.api.extension.ConditionEvaluationResult;
import org.junit.jupiter.api.extension.ExtensionContext;
import org.junit.jupiter.api.extension.ExtensionContext.*;

import java.lang.reflect.Method;
import java.util.Date;
import java.util.HashMap;
import java.util.logging.Logger;
import java.util.regex.Matcher;
import java.util.regex.Pattern;


public class BeforeEachExtension implements BeforeEachCallback {

    Pattern indexPattern = Pattern.compile(".*(\\d+)\\]$");

    private static final Logger LOGGER = Logger.getLogger( BeforeEachExtension.class.getName() );

    /**
     * Callback that is invoked before each test is invoked.
     *
     * @param context the current extension context; never {@code null}
     */
    @Override
    public void beforeEach(ExtensionContext context) throws Exception {
        LOGGER.info("BeforeEachExtension called");
        if (isUsingSlick()) {
            Store store = context.getStore(Namespace.create(context.getUniqueId()));
            LOGGER.info("Setting test to skip in case any @BeforeEach (setup) methods fail");
            store.put("skipTest", true);
            SlickJunitController controller = SlickJunitControllerFactory.getControllerInstance();
            if (context.getTestMethod().isPresent()) {
                Method testMethod = context.getTestMethod().get();
                //System.out.println(MessageFormat.format("Test found: {0}", testMethod.getName()));
                Result result = controller.getOrCreateResultFor(testMethod, context.getUniqueId(), context.getDisplayName());
                if(controller.getConfigurationSource().getConfigurationEntry(ConfigurationNames.SCHEDULE_TEST_MODE, "false").equalsIgnoreCase("true")) {
                    addDataDrivenAttributesIfNeeded(controller, context, result);
                    throw new Exception("Scheduling mode, not running test.");
                }
                validateDataDrivenArgumentsIfNeeded(context, result);
                Result update = new Result();
                update.setStarted(new Date());
                update.setReason("");
                update.setRunstatus("RUNNING");
                Result updatedResult;
                if(controller.getTestrun().getRunStarted() == null) {
                    Testrun trUpdate = new Testrun();
                    trUpdate.setRunStarted(new Date());
                    try {
                        controller.testrun = controller.getSlickClient().testrun(controller.getTestrun().getId()).update(trUpdate);
                    } catch (SlickError e) {
                        e.printStackTrace();
                        System.err.println("Slick Communication Error: problem updating testrun start time, not critical so continuing.");
                    }
                }
                try {
                    LOGGER.info("Updating result ID: " + result.getId() + " to RUNNING");
                    updatedResult = controller.getSlickClient().result(result.getId()).update(update);
                    SlickJunitController.currentResult.set(updatedResult);
                    //SlickTestWatcher.currentResult.set(controller.getSlickClient().result(result.getId()).get());
                } catch (SlickError e) {
                    LOGGER.severe("!! ERROR: Unable to set result to RUNNING. !!");
                    e.printStackTrace();
                    SlickJunitController.currentResult.set(null);
                }
            }
        }
    }

    boolean isUsingSlick() {
        boolean retval = false;

        SlickJunitController controller = SlickJunitControllerFactory.getControllerInstance();
        if(controller != null && SlickJunitController.isUsingSlick()) {
            retval = true;
        }
        LOGGER.info(retval ? "Using slick" : "Not using slick");
        return retval;
    }

    boolean resultIsRunningFromPreviousScheduling(Result result) {
        boolean retval = result != null && result.getAttributes() != null && "true".equalsIgnoreCase(result.getAttributes().get("scheduled"));
        LOGGER.info(retval ? "This test was previously scheduled" : "This test was NOT previously scheduled");
        return retval;
    }

    void validateDataDrivenArgumentsIfNeeded(ExtensionContext context, Result result) throws Exception {
        Matcher isDataDriven = indexPattern.matcher(context.getUniqueId());
        if(resultIsRunningFromPreviousScheduling(result) && isDataDriven.matches()) {
            Long index = Long.parseLong(isDataDriven.group(1));
            ArgumentsChecksumStore checksums = context.getStore(ExtensionContext.Namespace.create(ArgumentsChecksumStore.class, context.getRequiredTestMethod())).get("checksums", ArgumentsChecksumStore.class);
            if(checksums != null && result.getAttributes().containsKey("jupiterArgumentsChecksum") &&
                    !result.getAttributes().get("jupiterArgumentsChecksum").equalsIgnoreCase(checksums.getChecksum(index))) {
                throw new Exception("Invalid data driven arguments");
            }
            LOGGER.info("Data driven arguments validated");
        }
    }

    private void addDataDrivenAttributesIfNeeded(SlickJunitController controller, ExtensionContext context, Result result) throws Exception {
        Matcher isDataDriven = indexPattern.matcher(context.getUniqueId());
        if(isDataDriven.matches()) {
            Long index = Long.parseLong(isDataDriven.group(1));
            ArgumentsChecksumStore checksums = context.getStore(ExtensionContext.Namespace.create(ArgumentsChecksumStore.class, context.getRequiredTestMethod())).get("checksums", ArgumentsChecksumStore.class);
            if(checksums != null) {
                Result update = new Result();
                update.setAttributes(new HashMap<>(result.getAttributes()));
                update.getAttributes().put("jupiterArgumentsChecksum", checksums.getChecksum(index));
                LOGGER.info("Adding data driven attributes");
                controller.getSlickClient().result(result.getId()).update(update);
            }
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy