org.citrusframework.remote.controller.RunController Maven / Gradle / Ivy
/*
* Copyright 2006-2018 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 org.citrusframework.remote.controller;
import org.citrusframework.TestSource;
import org.citrusframework.main.CitrusApp;
import org.citrusframework.main.CitrusAppConfiguration;
import org.citrusframework.remote.CitrusRemoteConfiguration;
import org.citrusframework.spi.ResourcePathTypeResolver;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.net.URISyntaxException;
import java.nio.file.Path;
import java.util.*;
/**
* @author Christoph Deppisch
* @since 2.7.4
*/
public class RunController {
private static final Logger logger = LoggerFactory.getLogger(RunController.class);
/** Test engine to run the tests */
private String engine;
/** Include tests based on these test names patterns */
private String[] includes;
/** Default properties set as system properties */
private final Map defaultProperties = new LinkedHashMap<>();
private final CitrusRemoteConfiguration configuration;
/**
* Constructor with given configuration.
* @param configuration
*/
public RunController(CitrusRemoteConfiguration configuration) {
this.configuration = configuration;
this.engine = configuration.getEngine();
}
/**
* Run all tests found in classpath.
*/
public void runAll() {
runPackages(Collections.singletonList(""));
}
/**
* Run Citrus application with given test package names.
* @param packages
*/
public void runPackages(List packages) {
CitrusAppConfiguration citrusAppConfiguration = new CitrusAppConfiguration();
citrusAppConfiguration.setEngine(engine);
citrusAppConfiguration.setIncludes(Optional.ofNullable(includes).orElse(configuration.getIncludes()));
citrusAppConfiguration.setPackages(packages);
citrusAppConfiguration.setConfigClass(configuration.getConfigClass());
citrusAppConfiguration.setTestJar(configuration.getTestJar());
citrusAppConfiguration.addDefaultProperties(configuration.getDefaultProperties());
citrusAppConfiguration.addDefaultProperties(defaultProperties);
try {
citrusAppConfiguration.setTestJar(Path.of(ResourcePathTypeResolver.ROOT.toURI()).toFile());
run(citrusAppConfiguration);
} catch (URISyntaxException e) {
logger.error("Cannot transform URI {} to path", ResourcePathTypeResolver.ROOT, e);
}
}
/**
* Run Citrus application with given test class names.
* @param testSources
*/
public void runClasses(List testSources) {
CitrusAppConfiguration citrusAppConfiguration = new CitrusAppConfiguration();
citrusAppConfiguration.setEngine(engine);
citrusAppConfiguration.setTestSources(testSources);
citrusAppConfiguration.setTestJar(configuration.getTestJar());
citrusAppConfiguration.setConfigClass(configuration.getConfigClass());
citrusAppConfiguration.addDefaultProperties(configuration.getDefaultProperties());
citrusAppConfiguration.addDefaultProperties(defaultProperties);
try {
citrusAppConfiguration.setTestJar(Path.of(ResourcePathTypeResolver.ROOT.toURI()).toFile());
run(citrusAppConfiguration);
} catch (URISyntaxException e) {
logger.error("Cannot transform URI {} to path", ResourcePathTypeResolver.ROOT, e);
}
}
/**
* Run tests with default configuration.
*/
public void run() {
this.run(configuration);
}
/**
* Run Citrus application with given configuration and cached Citrus instance.
* @param citrusAppConfiguration
*/
private void run(CitrusAppConfiguration citrusAppConfiguration) {
CitrusApp citrusApp = new CitrusApp(citrusAppConfiguration);
citrusApp.run();
}
/**
* Sets the engine.
* @param engine
*/
public void setEngine(String engine) {
this.engine = engine;
}
/**
* Sets the includes.
*
* @param includes
*/
public void setIncludes(String[] includes) {
this.includes = includes;
}
/**
* Sets the defaultProperties.
*
* @param defaultProperties
*/
public void addDefaultProperties(Map defaultProperties) {
this.defaultProperties.putAll(defaultProperties);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy