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

org.eclipse.jetty.maven.plugin.JettyStartWarMojo Maven / Gradle / Ivy

There is a newer version: 11.0.24
Show newest version
//
// ========================================================================
// Copyright (c) 1995-2022 Mort Bay Consulting Pty Ltd and others.
//
// This program and the accompanying materials are made available under the
// terms of the Eclipse Public License v. 2.0 which is available at
// https://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
// which is available at https://www.apache.org/licenses/LICENSE-2.0.
//
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
// ========================================================================
//

package org.eclipse.jetty.maven.plugin;

import java.io.File;
import java.nio.file.Path;

import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
import org.apache.maven.plugins.annotations.ResolutionScope;
import org.eclipse.jetty.util.StringUtil;

/**
 * 

* This goal is used to run Jetty with any pre-assembled war. This goal does not have * to be used with a project of packaging type "war". *

*

* You can configure the "webApp" element with the location of either a war file or * an unpacked war that you wish to deploy - in either case, the webapp must be * fully compiled and assembled as this goal does not do anything other than start * jetty with the given webapp. If you do not configure the "webApp" element, then * the goal will default to using the war of the webapp project. *

*

* This goal is designed to be bound to a build phase, and NOT to be run at the * command line. It will not block waiting for jetty to execute, but rather continue * execution. *

*

* This goal is useful e.g. for launching a web app in Jetty as a target for unit-tested * HTTP client components via binding to the test-integration build phase. *

*

* You can configure this goal to run the webapp either in-process with maven, or * forked into a new process, or deployed into a {@code ${jetty.base}} directory. *

*/ @Mojo(name = "start-war", requiresDependencyResolution = ResolutionScope.RUNTIME) public class JettyStartWarMojo extends AbstractWebAppMojo { @Parameter (defaultValue = "${project.baseDir}/src/main/webapp") protected File webAppSourceDirectory; protected JettyEmbedder embedder; protected JettyForker forker; protected JettyHomeForker homeForker; @Override public void configureWebApp() throws Exception { super.configureWebApp(); //if a war has not been explicitly configured, use the one from the project if (StringUtil.isBlank(webApp.getWar())) { Path war = target.toPath().resolve(project.getBuild().getFinalName() + ".war"); webApp.setWar(war.toFile().getAbsolutePath()); } getLog().info("War = " + webApp.getWar()); } /** * Start a jetty instance in process to run given war. */ @Override public void startJettyEmbedded() throws MojoExecutionException { try { embedder = newJettyEmbedder(); embedder.setExitVm(false); embedder.setStopAtShutdown(false); embedder.start(); } catch (Exception e) { throw new MojoExecutionException("Error starting jetty", e); } } /** * Fork a jetty instance to run the given war. */ @Override public void startJettyForked() throws MojoExecutionException { try { forker = newJettyForker(); forker.setWaitForChild(false); //we never wait for child to finish forker.setMaxChildStartChecks(maxChildStartChecks); forker.setMaxChildStartCheckMs(maxChildStartCheckMs); forker.setJettyOutputFile(getJettyOutputFile("jetty-start-war.out")); forker.start(); //forks jetty instance } catch (Exception e) { throw new MojoExecutionException("Error starting jetty", e); } } /** * Fork a jetty distro to run the given war. */ @Override public void startJettyHome() throws MojoExecutionException { try { homeForker = newJettyHomeForker(); homeForker.setWaitForChild(false); //never wait for child tofinish homeForker.setMaxChildStartCheckMs(maxChildStartCheckMs); homeForker.setMaxChildStartChecks(maxChildStartChecks); homeForker.setJettyOutputFile(getJettyOutputFile("jetty-start-war.out")); homeForker.start(); //forks a jetty distro } catch (Exception e) { throw new MojoExecutionException("Error starting jetty", e); } } @Override protected void verifyPomConfiguration() throws MojoExecutionException { //Do nothing here, as we want the user to configure a war to deploy, //or we default to the webapp that is running the jetty plugin, but //we need to delay that decision until configureWebApp(). } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy