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

com.consol.citrus.dsl.builder.SeleniumActionBuilder Maven / Gradle / Ivy

/*
 * Copyright 2006-2017 the original author or authors.
 *
 * Licensed 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 com.consol.citrus.dsl.builder;

import com.consol.citrus.TestAction;
import com.consol.citrus.dsl.actions.DelegatingTestAction;
import com.consol.citrus.exceptions.CitrusRuntimeException;
import com.consol.citrus.selenium.actions.*;
import com.consol.citrus.selenium.endpoint.SeleniumBrowser;
import com.consol.citrus.selenium.model.PageValidator;
import com.consol.citrus.selenium.model.WebPage;
import com.consol.citrus.util.FileUtils;
import org.openqa.selenium.By;
import org.springframework.core.io.Resource;

import java.io.IOException;
import java.nio.charset.Charset;
import java.util.Arrays;
import java.util.List;

/**
 * Action builds selenium related actions.
 * 
 * @author Christoph Deppisch
 * @since 2.7
 */
public class SeleniumActionBuilder extends AbstractTestActionBuilder> {

    /** Selenium browser */
    private SeleniumBrowser seleniumBrowser;

	/**
	 * Constructor using action field.
	 * @param action
	 */
	public SeleniumActionBuilder(DelegatingTestAction action) {
	    super(action);
    }

	/**
	 * Default constructor.
	 */
	public SeleniumActionBuilder() {
		super(new DelegatingTestAction<>());
	}

	/**
	 * Use a custom selenium browser.
	 */
	public SeleniumActionBuilder browser(SeleniumBrowser seleniumBrowser) {
		this.seleniumBrowser = seleniumBrowser;
		return this;
	}

    /**
     * Start browser instance.
     */
    public SeleniumActionBuilder start() {
        action(new StartBrowserAction());
        return this;
    }

    /**
     * Start explicit browser instance.
     */
    public SeleniumActionBuilder start(SeleniumBrowser seleniumBrowser) {
        browser(seleniumBrowser);
        action(new StartBrowserAction());
        return this;
    }

    /**
     * Stop browser instance.
     */
    public SeleniumActionBuilder stop() {
        action(new StopBrowserAction());
        return this;
    }

    /**
     * Stop explicit browser instance.
     */
    public SeleniumActionBuilder stop(SeleniumBrowser seleniumBrowser) {
        browser(seleniumBrowser);
        action(new StopBrowserAction());
        return this;
    }

    /**
     * Alert element.
     */
    public AlertActionBuilder alert() {
        AlertAction action = new AlertAction();
        action(action);
        return new AlertActionBuilder(action);
    }

    /**
     * Navigate action.
     */
    public SeleniumActionBuilder navigate(String page) {
        NavigateAction action = new NavigateAction();
        action.setPage(page);
        action(action);
        return this;
    }

    /**
     * Page action.
     */
    public PageActionBuilder page(WebPage page) {
        PageAction action = new PageAction();
        action.setPage(page);
        action(action);
        return new PageActionBuilder(action);
    }

    /**
     * Page action.
     */
    public PageActionBuilder page(Class pageType) {
        PageAction action = new PageAction();
        action.setType(pageType.getName());
        action(action);
        return new PageActionBuilder(action);
    }

	/**
     * Finds element.
     */
    public FindElementActionBuilder find() {
		FindElementAction action = new FindElementAction();
        action(action);
        return new FindElementActionBuilder(action);
    }

    /**
     * Dropdown select single option action.
     */
    public ElementActionBuilder select(String option) {
        DropDownSelectAction action = new DropDownSelectAction();
        action.setOption(option);
        action(action);
        return new ElementActionBuilder(action);
    }

    /**
     * Dropdown select multiple options action.
     */
    public ElementActionBuilder select(String ... options) {
        DropDownSelectAction action = new DropDownSelectAction();
        action.setOptions(Arrays.asList(options));
        action(action);
        return new ElementActionBuilder(action);
    }

    /**
     * Set input action.
     */
    public ElementActionBuilder setInput(String value) {
		SetInputAction action = new SetInputAction();
		action.setValue(value);
        action(action);
        return new ElementActionBuilder(action);
    }

    /**
     * Check input action.
     */
    public ElementActionBuilder checkInput(boolean checked) {
		CheckInputAction action = new CheckInputAction();
		action.setChecked(checked);
        action(action);
        return new ElementActionBuilder(action);
    }

    /**
     * Clicks element.
     */
    public ElementActionBuilder click() {
		ClickAction action = new ClickAction();
        action(action);
        return new ElementActionBuilder(action);
    }

    /**
     * Hover element.
     */
    public ElementActionBuilder hover() {
		HoverAction action = new HoverAction();
        action(action);
        return new ElementActionBuilder(action);
    }

    /**
     * Clear browser cache.
     */
    public SeleniumActionBuilder clearCache() {
        action(new ClearBrowserCacheAction());
        return this;
    }

    /**
     * Make screenshot.
     */
    public SeleniumActionBuilder screenshot() {
        action(new MakeScreenshotAction());
        return this;
    }

    /**
     * Make screenshot with custom output directory.
     */
    public SeleniumActionBuilder screenshot(String outputDir) {
        MakeScreenshotAction action = new MakeScreenshotAction();
        action.setOutputDir(outputDir);
        action(action);
        return this;
    }

    /**
     * Store file.
     * @param filePath
     */
    public SeleniumActionBuilder store(String filePath) {
        StoreFileAction action = new StoreFileAction();
        action.setFilePath(filePath);
        action(action);
        return this;
    }

    /**
     * Get stored file.
     * @param fileName
     */
    public SeleniumActionBuilder getStored(String fileName) {
        GetStoredFileAction action = new GetStoredFileAction();
        action.setFileName(fileName);
        action(action);
        return this;
    }

    /**
     * Wait until element meets condition.
     */
    public WaitUntilActionBuilder waitUntil() {
        WaitUntilAction action = new WaitUntilAction();
        action(action);
        return new WaitUntilActionBuilder(action);
    }

    /**
     * Execute JavaScript.
     */
    public JavaScriptActionBuilder javascript(String script) {
        JavaScriptAction action = new JavaScriptAction();
        action.setScript(script);
        action(action);
        return new JavaScriptActionBuilder(action);
    }

    /**
     * Execute JavaScript.
     */
    public JavaScriptActionBuilder javascript(Resource script) {
        return javascript(script, FileUtils.getDefaultCharset());
    }

    /**
     * Execute JavaScript.
     */
    public JavaScriptActionBuilder javascript(Resource script, Charset charset) {
        JavaScriptAction action = new JavaScriptAction();
        try {
            action.setScript(FileUtils.readToString(script, charset));
        } catch (IOException e) {
            throw new CitrusRuntimeException("Failed to read script resource", e);
        }
        action(action);
        return new JavaScriptActionBuilder(action);
    }

    /**
     * Open window.
     */
    public WindowActionBuilder open() {
        OpenWindowAction action = new OpenWindowAction();
        action(action);
        return new WindowActionBuilder(action);
    }

    /**
     * Close window.
     */
    public WindowActionBuilder close() {
        CloseWindowAction action = new CloseWindowAction();
        action(action);
        return new WindowActionBuilder(action);
    }

    /**
     * Switch window.
     */
    public WindowActionBuilder focus() {
        SwitchWindowAction action = new SwitchWindowAction();
        action(action);
        return new WindowActionBuilder(action);
    }

    /**
     * Prepare selenium action.
     */
    private  T action(T delegate) {
        if (seleniumBrowser != null) {
            delegate.setBrowser(seleniumBrowser);
        }

        action.setDelegate(delegate);
        return delegate;
    }

    /**
     * Customize alert action.
     */
    public class AlertActionBuilder implements TestActionBuilder {

        /** Alert action */
        private final AlertAction action;

        /**
         * Default constructor.
         * @param action
         */
        public AlertActionBuilder(AlertAction action) {
            this.action = action;
        }

        /**
         * Add alert text validation.
         * @param text
         * @return
         */
        public AlertActionBuilder text(String text) {
            action.setText(text);
            return this;
        }

        /**
         * Accept alert dialog.
         * @return
         */
        public AlertActionBuilder accept() {
            action.setAccept(true);
            return this;
        }

        /**
         * Dismiss alert dialog.
         * @return
         */
        public AlertActionBuilder dismiss() {
            action.setAccept(false);
            return this;
        }

        @Override
        public TestAction build() {
            return SeleniumActionBuilder.this.build();
        }
    }

    /**
     * Customize page action.
     */
    public class PageActionBuilder implements TestActionBuilder {

        /** Alert action */
        private final PageAction action;

        /**
         * Default constructor.
         * @param action
         */
        public PageActionBuilder(PageAction action) {
            this.action = action;
        }

        /**
         * Perform page validation.
         * @return
         */
        public PageActionBuilder validate() {
            action.setAction("validate");
            return this;
        }

        /**
         * Set page validator.
         * @param validator
         * @return
         */
        public PageActionBuilder validator(PageValidator validator) {
            action.setValidator(validator);
            return this;
        }

        /**
         * Set page action method to execute.
         * @param method
         * @return
         */
        public PageActionBuilder execute(String method) {
            action.setAction(method);
            return this;
        }

        /**
         * Set page action argument.
         * @param arg
         * @return
         */
        public PageActionBuilder argument(String arg) {
            action.getArguments().add(arg);
            return this;
        }

        /**
         * Set page action arguments.
         * @param args
         * @return
         */
        public PageActionBuilder arguments(String ... args) {
            action.setArguments(Arrays.asList(args));
            return this;
        }

        /**
         * Set page action arguments.
         * @param args
         * @return
         */
        public PageActionBuilder arguments(List args) {
            action.setArguments(args);
            return this;
        }

        @Override
        public TestAction build() {
            return SeleniumActionBuilder.this.build();
        }
    }

    /**
     * Customize javascript action.
     */
    public class JavaScriptActionBuilder implements TestActionBuilder {

        /** JavaScript action */
        private final JavaScriptAction action;

        /**
         * Default constructor.
         * @param action
         */
        public JavaScriptActionBuilder(JavaScriptAction action) {
            this.action = action;
        }

        /**
         * Add script argument.
         * @param arg
         * @return
         */
        public JavaScriptActionBuilder argument(Object arg) {
            action.getArguments().add(arg);
            return this;
        }

        /**
         * Add expected error.
         * @param errors
         * @return
         */
        public JavaScriptActionBuilder errors(String ... errors) {
            action.setExpectedErrors(Arrays.asList(errors));
            return this;
        }

        @Override
        public TestAction build() {
            return SeleniumActionBuilder.this.build();
        }
    }

    /**
     * Customize wait until action.
     */
    public class WaitUntilActionBuilder extends ElementActionBuilder {

        /** WaitUntil action */
        private final WaitUntilAction action;

        /**
         * Default constructor.
         * @param action
         */
        public WaitUntilActionBuilder(WaitUntilAction action) {
            super(action);
            this.action = action;
        }

        /**
         * Add visible condition.
         * @return
         */
        public WaitUntilActionBuilder visible() {
            action.setCondition("visible");
            return this;
        }

        /**
         * Add hidden condition.
         * @return
         */
        public WaitUntilActionBuilder hidden() {
            action.setCondition("hidden");
            return this;
        }

        /**
         * Add timeout condition.
         * @return
         */
        public WaitUntilActionBuilder timeout(Long timeout) {
            action.setTimeout(timeout);
            return this;
        }

        @Override
        public WaitUntilActionBuilder element(By by) {
            super.element(by);
            return this;
        }

        @Override
        public WaitUntilActionBuilder element(String property, String propertyValue) {
            super.element(property, propertyValue);
            return this;
        }
    }

    /**
     * Window accessing action.
     */
    public class WindowActionBuilder implements TestActionBuilder {

        /** Window action */
        private final SeleniumWindowAction action;

        /**
         * Default constructor.
         * @param action
         */
        public WindowActionBuilder(SeleniumWindowAction action) {
            this.action = action;
        }

        /**
         * Set window name.
         * @param name
         * @return
         */
        public WindowActionBuilder window(String name) {
            action.setWindowName(name);
            return this;
        }

        @Override
        public TestAction build() {
            return SeleniumActionBuilder.this.build();
        }
    }

    /**
     * Customize element selecting action.
     */
    public class ElementActionBuilder implements TestActionBuilder {

        /** Element action */
        private final T action;

        /**
         * Default constructor.
         * @param action
         */
        public ElementActionBuilder(T action) {
            this.action = action;
        }

        /**
         * Add element selector.
         * @param by
         * @return
         */
        public ElementActionBuilder element(By by) {
            action.setBy(by);
            return this;
        }

        /**
         * Add element property and value selector.
         * @return
         */
        public ElementActionBuilder element(String property, String propertyValue) {
            action.setProperty(property);
            action.setPropertyValue(propertyValue);
            return this;
        }

        @Override
        public TestAction build() {
            return SeleniumActionBuilder.this.build();
        }
    }

    /**
     * Customize element selecting action.
     */
    public class FindElementActionBuilder extends ElementActionBuilder {

        /** Find element action */
        private final FindElementAction action;

        /**
         * Default constructor.
         * @param action
         */
        public FindElementActionBuilder(FindElementAction action) {
            super(action);
            this.action = action;
        }

        /**
         * Add tag name validation.
         * @param tagName
         * @return
         */
        public FindElementActionBuilder tagName(String tagName) {
            action.setTagName(tagName);
            return this;
        }

        /**
         * Add text validation.
         * @param text
         * @return
         */
        public FindElementActionBuilder text(String text) {
            action.setText(text);
            return this;
        }

        /**
         * Add attribute validation.
         * @param name
         * @param value
         * @return
         */
        public FindElementActionBuilder attribute(String name, String value) {
            action.getAttributes().put(name, value);
            return this;
        }

        /**
         * Add css style validation.
         * @param name
         * @param value
         * @return
         */
        public FindElementActionBuilder style(String name, String value) {
            action.getStyles().put(name, value);
            return this;
        }

        /**
         * Add enabled validation.
         * @param enabled
         * @return
         */
        public FindElementActionBuilder enabled(boolean enabled) {
            action.setEnabled(enabled);
            return this;
        }

        /**
         * Add displayed validation.
         * @param displayed
         * @return
         */
        public FindElementActionBuilder displayed(boolean displayed) {
            action.setDisplayed(displayed);
            return this;
        }

        @Override
        public FindElementActionBuilder element(By by) {
            super.element(by);
            return this;
        }

        @Override
        public FindElementActionBuilder element(String property, String propertyValue) {
            super.element(property, propertyValue);
            return this;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy