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

com.epam.jdi.uitests.gui.sikuli.elements.actions.ActionScenarios Maven / Gradle / Ivy

package com.epam.jdi.uitests.gui.sikuli.elements.actions;
/*
 * Copyright 2004-2016 EPAM Systems
 *
 * This file is part of JDI project.
 *
 * JDI is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * JDI is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; 
 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with JDI. If not, see .
 */



import com.epam.commons.Timer;
import com.epam.commons.linqinterfaces.JAction;
import com.epam.jdi.uitests.core.logger.LogLevels;
import com.epam.jdi.uitests.core.settings.JDISettings;
import com.epam.jdi.uitests.gui.sikuli.elements.BaseElement;

import java.util.function.Function;
import java.util.function.Supplier;

import static com.epam.jdi.uitests.core.reporting.PerformanceStatistic.addStatistic;
import static com.epam.jdi.uitests.core.settings.JDISettings.*;
import static java.lang.String.format;

/**
 * Created by Roman_Iovlev on 8/10/2015.
 */
public class ActionScenarios {
    private BaseElement element;

    public ActionScenarios setElement(BaseElement element) {
        this.element = element;
        return this;
    }

    public void actionScenario(String actionName, JAction jAction, LogLevels logSettings) {
        element.logAction(actionName, logSettings);
        Timer timer = new Timer();
        new Timer(timeouts.currentTimeoutSec).wait(() -> {
            jAction.invoke();
            return true;
        });
        logger.info(actionName + " done");
        addStatistic(timer.timePassedInMSec());
    }

    public  TResult resultScenario(String actionName, Supplier jAction, Function logResult, LogLevels level) {
        element.logAction(actionName);
        Timer timer = new Timer();
        TResult result = new Timer(timeouts.currentTimeoutSec)
                .getResultByCondition(jAction::get, res -> true);
        if (result == null)
            throw asserter.exception("Do action %s failed. Can't got result", actionName);
        String stringResult = (logResult == null)
                ? result.toString()
                : JDISettings.asserter.silent(() -> logResult.apply(result));
        Long timePassed = timer.timePassedInMSec();
        addStatistic(timer.timePassedInMSec());
        toLog(format("Get result '%s' in %s seconds", stringResult,
                format("%.2f", (double) timePassed / 1000)), level);
        return result;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy