ch.sourcepond.maven.plugin.jenkins.process.ProcessFacade Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jenkins-maven-plugin Show documentation
Show all versions of jenkins-maven-plugin Show documentation
The Jenkins Maven Plugin allows to use the Jenkins CLI (command line interface) from within a Maven build.
It allows the execution of any command supported by the CLI, see https://wiki.jenkins-ci.org/display/JENKINS/Jenkins+CLI
for further information. Therefore, it downloads the current jenkins-cli.jar from ${project.ciManagement.url}/jnlpJars/jenkins-cli.jar
and uses that artifact for interacting with the Jenkins server. The architecture of the Jenkins Maven Plugin follows the UNIX philosophy
"do one thing and do it well": it does not provide any logic for specific tasks, for instance creating job configuration files.
This can be done with another, more appropriate plugin and its result can then be specified as stdin to the Jenkins Maven Plugin.
/*Copyright (C) 2015 Roland Hauser,
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 ch.sourcepond.maven.plugin.jenkins.process;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugin.logging.Log;
import ch.sourcepond.maven.plugin.jenkins.config.Config;
/**
* Facade to create and execute a native process to execute a CLI command.
*/
public interface ProcessFacade {
/**
* Executes the CLI with the command, options and arguments specified by the
* {@link Config} parameter.
*
* @param pLog
* Log where to redirect stdout and stderr,
* must not be {@code null}
* @param pConfig
* {@link Config} instance which holds all necessary
* configuration.
* @throws MojoExecutionException
* Thrown, if something went wrong.
*/
void execute(Log pLog, Config pConfig) throws MojoExecutionException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy