From 0155dbf373621f9d4dd70242981f76e73f9aa543 Mon Sep 17 00:00:00 2001 From: Shannon Carey Date: Sun, 14 Aug 2016 16:41:08 -0500 Subject: [PATCH] Add option to include runtime and provided - New "provided" value for classpathScope includes both runtime and provided dependencies - Closes #60 --- src/it/git-issue-60-exec/pom.xml | 62 ++++++++++++++++++ .../src/main/java/gitissue60/Main.java | 31 +++++++++ .../src/main/resources/log4j.properties | 8 +++ src/it/git-issue-60-exec/verify.groovy | 25 ++++++++ src/it/git-issue-60-java/pom.xml | 63 +++++++++++++++++++ .../src/main/java/gitissue60/Main.java | 31 +++++++++ .../src/main/resources/log4j.properties | 8 +++ src/it/git-issue-60-java/verify.groovy | 30 +++++++++ .../codehaus/mojo/exec/AbstractExecMojo.java | 26 +++++++- .../java/org/codehaus/mojo/exec/ExecMojo.java | 6 +- 10 files changed, 285 insertions(+), 5 deletions(-) create mode 100644 src/it/git-issue-60-exec/pom.xml create mode 100644 src/it/git-issue-60-exec/src/main/java/gitissue60/Main.java create mode 100644 src/it/git-issue-60-exec/src/main/resources/log4j.properties create mode 100644 src/it/git-issue-60-exec/verify.groovy create mode 100644 src/it/git-issue-60-java/pom.xml create mode 100644 src/it/git-issue-60-java/src/main/java/gitissue60/Main.java create mode 100644 src/it/git-issue-60-java/src/main/resources/log4j.properties create mode 100644 src/it/git-issue-60-java/verify.groovy diff --git a/src/it/git-issue-60-exec/pom.xml b/src/it/git-issue-60-exec/pom.xml new file mode 100644 index 00000000..ac7fbcfe --- /dev/null +++ b/src/it/git-issue-60-exec/pom.xml @@ -0,0 +1,62 @@ + + 4.0.0 + org.cb.maven.plugins.exec + project15 + 0.1 + + + Apache License 2 + http://www.apache.org/licenses/LICENSE-2.0.txt + repo + + + + + + org.slf4j + slf4j-api + 1.7.21 + + + org.slf4j + slf4j-log4j12 + 1.7.21 + runtime + + + log4j + log4j + 1.2.17 + provided + + + + + + + + org.codehaus.mojo + exec-maven-plugin + @project.version@ + + + test + + exec + + + + + provided + ${JAVA_HOME}/bin/java + + -classpath + + gitissue60.Main + + + + + + + diff --git a/src/it/git-issue-60-exec/src/main/java/gitissue60/Main.java b/src/it/git-issue-60-exec/src/main/java/gitissue60/Main.java new file mode 100644 index 00000000..36ab1c9a --- /dev/null +++ b/src/it/git-issue-60-exec/src/main/java/gitissue60/Main.java @@ -0,0 +1,31 @@ +package gitissue60; + +/* + * Copyright 2005 The Codehaus. + * + * 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. + */ + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +/** + * @version $Id$ + */ +public class Main +{ + private static final Logger LOGGER = LoggerFactory.getLogger( Main.class ); + public static void main( String[] args ) throws Exception { + LOGGER.info( "Can you hear me, Major Tom?" ); + } +} diff --git a/src/it/git-issue-60-exec/src/main/resources/log4j.properties b/src/it/git-issue-60-exec/src/main/resources/log4j.properties new file mode 100644 index 00000000..eb83c002 --- /dev/null +++ b/src/it/git-issue-60-exec/src/main/resources/log4j.properties @@ -0,0 +1,8 @@ +# Root logger option +log4j.rootLogger=INFO, file + +# Direct log messages to stdout +log4j.appender.file=org.apache.log4j.FileAppender +log4j.appender.file.File=exec.log +log4j.appender.file.layout=org.apache.log4j.PatternLayout +log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n \ No newline at end of file diff --git a/src/it/git-issue-60-exec/verify.groovy b/src/it/git-issue-60-exec/verify.groovy new file mode 100644 index 00000000..9ffe1022 --- /dev/null +++ b/src/it/git-issue-60-exec/verify.groovy @@ -0,0 +1,25 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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. + */ + +File execLog = new File(basedir, 'exec.log') +assert execLog.exists() +assert execLog.getText().contains('Can you hear me, Major Tom?') + +File buildLog = new File(basedir, 'build.log') +assert buildLog.exists() \ No newline at end of file diff --git a/src/it/git-issue-60-java/pom.xml b/src/it/git-issue-60-java/pom.xml new file mode 100644 index 00000000..4550471d --- /dev/null +++ b/src/it/git-issue-60-java/pom.xml @@ -0,0 +1,63 @@ + + 4.0.0 + org.cb.maven.plugins.exec + project15 + 0.1 + + + Apache License 2 + http://www.apache.org/licenses/LICENSE-2.0.txt + repo + + + + + + org.slf4j + slf4j-api + 1.7.21 + + + org.slf4j + slf4j-log4j12 + 1.7.21 + runtime + + + log4j + log4j + 1.2.17 + provided + + + junit + junit + 3.8.1 + test + + + + + + + + org.codehaus.mojo + exec-maven-plugin + @project.version@ + + + test + + java + + + + + gitissue60.Main + provided + + + + + + diff --git a/src/it/git-issue-60-java/src/main/java/gitissue60/Main.java b/src/it/git-issue-60-java/src/main/java/gitissue60/Main.java new file mode 100644 index 00000000..36ab1c9a --- /dev/null +++ b/src/it/git-issue-60-java/src/main/java/gitissue60/Main.java @@ -0,0 +1,31 @@ +package gitissue60; + +/* + * Copyright 2005 The Codehaus. + * + * 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. + */ + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +/** + * @version $Id$ + */ +public class Main +{ + private static final Logger LOGGER = LoggerFactory.getLogger( Main.class ); + public static void main( String[] args ) throws Exception { + LOGGER.info( "Can you hear me, Major Tom?" ); + } +} diff --git a/src/it/git-issue-60-java/src/main/resources/log4j.properties b/src/it/git-issue-60-java/src/main/resources/log4j.properties new file mode 100644 index 00000000..eb83c002 --- /dev/null +++ b/src/it/git-issue-60-java/src/main/resources/log4j.properties @@ -0,0 +1,8 @@ +# Root logger option +log4j.rootLogger=INFO, file + +# Direct log messages to stdout +log4j.appender.file=org.apache.log4j.FileAppender +log4j.appender.file.File=exec.log +log4j.appender.file.layout=org.apache.log4j.PatternLayout +log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n \ No newline at end of file diff --git a/src/it/git-issue-60-java/verify.groovy b/src/it/git-issue-60-java/verify.groovy new file mode 100644 index 00000000..d7cbe3e2 --- /dev/null +++ b/src/it/git-issue-60-java/verify.groovy @@ -0,0 +1,30 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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. + */ + +File execLog = new File(basedir, 'exec.log') +assert execLog.exists() +assert execLog.getText().contains('Can you hear me, Major Tom?') + +File buildLog = new File(basedir, 'build.log') +assert buildLog.exists() +def buildLogText = buildLog.getText() +assert buildLogText.contains( "Adding project dependency artifact: slf4j-api to classpath" ) +assert buildLogText.contains( "Adding project dependency artifact: log4j to classpath" ) +assert buildLogText.contains( "Adding project dependency artifact: slf4j-log4j12 to classpath" ) +assert !buildLogText.contains( "Adding project dependency artifact: junit to classpath" ) \ No newline at end of file diff --git a/src/main/java/org/codehaus/mojo/exec/AbstractExecMojo.java b/src/main/java/org/codehaus/mojo/exec/AbstractExecMojo.java index 0899b53b..bb4ccb5a 100644 --- a/src/main/java/org/codehaus/mojo/exec/AbstractExecMojo.java +++ b/src/main/java/org/codehaus/mojo/exec/AbstractExecMojo.java @@ -20,6 +20,7 @@ */ import java.io.File; +import java.util.HashSet; import java.util.List; import org.apache.maven.artifact.Artifact; @@ -107,8 +108,17 @@ public abstract class AbstractExecMojo private String commandlineArgs; /** - * Defines the scope of the classpath passed to the plugin. Set to compile,test,runtime or system depending on your - * needs. Since 1.1.2, the default value is 'runtime' instead of 'compile'. + * Defines the scope of the classpath passed to the plugin. + * + * + * + * Since 1.1.2, the default value is 'runtime' instead of 'compile'. */ @Parameter( property = "exec.classpathScope", defaultValue = "runtime" ) protected String classpathScope; @@ -184,6 +194,18 @@ else if ( "runtime".equals( classpathScope ) ) theClasspathFiles.add( new File( project.getBuild().getOutputDirectory() ) ); } } + else if ( "provided".equals( classpathScope ) ) + { + // "compile" gives compile, provided, and system scopes + // "runtime" gives compile and runtime scopes + HashSet artifactSet = new HashSet<>( project.getCompileArtifacts() ); + artifactSet.addAll( project.getRuntimeArtifacts() ); + artifacts.addAll( artifactSet ); + if ( addOutputToClasspath ) + { + theClasspathFiles.add( new File( project.getBuild().getOutputDirectory() ) ); + } + } else if ( "system".equals( classpathScope ) ) { artifacts.addAll( project.getSystemArtifacts() ); diff --git a/src/main/java/org/codehaus/mojo/exec/ExecMojo.java b/src/main/java/org/codehaus/mojo/exec/ExecMojo.java index 24e42a84..d40c8f4c 100644 --- a/src/main/java/org/codehaus/mojo/exec/ExecMojo.java +++ b/src/main/java/org/codehaus/mojo/exec/ExecMojo.java @@ -572,9 +572,9 @@ private String computeClasspathString( AbstractPath specifiedClasspath ) */ private List computePath( AbstractPath specifiedClasspath ) { - List artifacts = new ArrayList(); - List theClasspathFiles = new ArrayList(); - List resultList = new ArrayList(); + List artifacts = new ArrayList<>(); + List theClasspathFiles = new ArrayList<>(); + List resultList = new ArrayList<>(); collectProjectArtifactsAndClasspath( artifacts, theClasspathFiles );