summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Donszelmann <Mark.Donszelmann@gmail.com>2009-10-03 08:18:57 +0200
committerMark Donszelmann <Mark.Donszelmann@gmail.com>2009-10-03 08:18:57 +0200
commitf16721c64008697a5b37c002f3b201d15e556c7a (patch)
tree6b8d87dd6e709f256f487870f2232ccbe7239cb3
parent4ba4c1e4029bbfd271d362413f4f4b874853763b (diff)
downloadmaven-nar-plugin-f16721c64008697a5b37c002f3b201d15e556c7a.tar.gz
maven-nar-plugin-f16721c64008697a5b37c002f3b201d15e556c7a.tar.bz2
maven-nar-plugin-f16721c64008697a5b37c002f3b201d15e556c7a.tar.xz
maven-nar-plugin-f16721c64008697a5b37c002f3b201d15e556c7a.zip
Added jni test; changed goals for running run-its tests
-rw-r--r--ReleaseNotes.txt12
-rw-r--r--pom.xml9
-rw-r--r--src/it/executable/pom.xml8
-rw-r--r--src/it/jni/pom.xml81
-rw-r--r--src/it/jni/src/main/c/HelloWorldJNI.c16
-rw-r--r--src/it/jni/src/main/java/com/mycompany/mypackage/HelloWorldJNI.java15
-rw-r--r--src/it/jni/src/test/java/HelloWorldJNITest.java25
-rw-r--r--src/site/apt/HelloWorld.apt6
8 files changed, 168 insertions, 4 deletions
diff --git a/ReleaseNotes.txt b/ReleaseNotes.txt
index e2cc31a..83838d3 100644
--- a/ReleaseNotes.txt
+++ b/ReleaseNotes.txt
@@ -13,6 +13,18 @@ and cpptasks-parallel.
Bugs
+- Excecutable needs a test to run and verify the output of Executable.
+
+- When it test fails it seems not reported in main pom, refer to executable
+
+- nar-integration (our plugin copy) tests are not run when maven.tests.skip=true is set...
+while they are run when in the configuration (plugin has different name) skip is set.
+
+- When run from run-its, executable fails to create. The build file shows:
+
+Error looking up lifecycle mapping to retrieve optional mojos. Lifecycle ID: default. Error: Component descriptor cannot be found in the component repository: org.apache.maven.lifecycle.mapping.LifecycleMappingnar.
+org.codehaus.plexus.component.repository.exception.ComponentLookupException: Component descriptor cannot be found in the component repository: org.apache.maven.lifecycle.mapping.LifecycleMappingnar.
+
- When the calculated AOL is not found in aol.properties the error message is misleading:
[INFO] [nar:nar-download {execution: default-nar-download}]
diff --git a/pom.xml b/pom.xml
index a752945..ee721d6 100644
--- a/pom.xml
+++ b/pom.xml
@@ -131,11 +131,18 @@
<artifactId>maven-invoker-plugin</artifactId>
<version>1.4</version>
<configuration>
- <debug>true</debug>
+ <debug>false</debug>
+ <!-- FAILS to run, see ReleaseNotes
+ <cloneProjectsTo>${project.build.directory}/it</cloneProjectsTo>
+ -->
<pomExcludes>
<pomExclude>it-parent/**</pomExclude>
</pomExcludes>
<localRepositoryPath>${project.build.directory}/it-repo</localRepositoryPath>
+ <goals>
+ <goal>clean</goal>
+ <goal>integration-test</goal>
+ </goals>
</configuration>
<executions>
<execution>
diff --git a/src/it/executable/pom.xml b/src/it/executable/pom.xml
index 00bf1c8..98b664e 100644
--- a/src/it/executable/pom.xml
+++ b/src/it/executable/pom.xml
@@ -39,9 +39,11 @@ under the License.
</description>
<url>http://maven.apache.org/</url>
+<!--
<properties>
<maven.test.skip>true</maven.test.skip>
</properties>
+-->
<build>
<defaultGoal>integration-test</defaultGoal>
@@ -58,6 +60,12 @@ under the License.
</libraries>
</configuration>
</plugin>
+ <plugin>
+ <artifactId>maven-surefire-plugin</artifactId>
+ <configuration>
+ <skip>true</skip>
+ </configuration>
+ </plugin>
</plugins>
</build>
</project>
diff --git a/src/it/jni/pom.xml b/src/it/jni/pom.xml
new file mode 100644
index 0000000..486ac48
--- /dev/null
+++ b/src/it/jni/pom.xml
@@ -0,0 +1,81 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<!--
+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.
+-->
+
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+ <modelVersion>4.0.0</modelVersion>
+
+ <parent>
+ <groupId>org.apache.maven.its.nar</groupId>
+ <artifactId>it-parent</artifactId>
+ <version>1.0-SNAPSHOT</version>
+ <relativePath>../it-parent/pom.xml</relativePath>
+ </parent>
+
+ <artifactId>jni</artifactId>
+ <packaging>nar</packaging>
+
+ <name>Maven NAR JNI Test</name>
+ <version>1.0-SNAPSHOT</version>
+ <description>
+ Simple JNI Library
+ </description>
+ <url>http://maven.apache.org/</url>
+<!--
+ <properties>
+ <maven.test.skip>true</maven.test.skip>
+ </properties>
+-->
+ <build>
+ <defaultGoal>integration-test</defaultGoal>
+ <plugins>
+ <plugin>
+ <artifactId>maven-nar-plugin</artifactId>
+ <extensions>true</extensions>
+ <configuration>
+ <cpp>
+ <debug>true</debug>
+ </cpp>
+ <libraries>
+ <library>
+ <type>jni</type>
+ <narSystemPackage>com.mycompany.mypackage</narSystemPackage>
+ <linkCPP>false</linkCPP>
+ </library>
+ </libraries>
+ </configuration>
+ </plugin>
+ <plugin>
+ <artifactId>maven-surefire-plugin</artifactId>
+ <configuration>
+ <skip>true</skip>
+ </configuration>
+ </plugin>
+ </plugins>
+ </build>
+ <dependencies>
+ <dependency>
+ <groupId>junit</groupId>
+ <artifactId>junit</artifactId>
+ <version>3.8.2</version>
+ <scope>test</scope>
+ </dependency>
+ </dependencies>
+</project>
diff --git a/src/it/jni/src/main/c/HelloWorldJNI.c b/src/it/jni/src/main/c/HelloWorldJNI.c
new file mode 100644
index 0000000..716722e
--- /dev/null
+++ b/src/it/jni/src/main/c/HelloWorldJNI.c
@@ -0,0 +1,16 @@
+#include <stdio.h>
+#include "com_mycompany_mypackage_HelloWorldJNI.h"
+
+JNIEXPORT jstring JNICALL Java_com_mycompany_mypackage_HelloWorldJNI_sayHello( JNIEnv *env, jobject obj ) {
+ jstring value; /* the return value */
+
+ char buf[40]; /* working buffer (really only need 20 ) */
+
+
+ sprintf ( buf, "%s", "Hello NAR World!" );
+
+ value = (*env)->NewStringUTF( env, buf );
+
+ return value;
+}
+
diff --git a/src/it/jni/src/main/java/com/mycompany/mypackage/HelloWorldJNI.java b/src/it/jni/src/main/java/com/mycompany/mypackage/HelloWorldJNI.java
new file mode 100644
index 0000000..2af3f3c
--- /dev/null
+++ b/src/it/jni/src/main/java/com/mycompany/mypackage/HelloWorldJNI.java
@@ -0,0 +1,15 @@
+package com.mycompany.mypackage;
+
+public class HelloWorldJNI {
+ static {
+ NarSystem.loadLibrary();
+ }
+
+ public native String sayHello();
+
+ public static void main( String[] args ) {
+ HelloWorldJNI app = new HelloWorldJNI();
+ System.out.println( app.sayHello() );
+ }
+}
+
diff --git a/src/it/jni/src/test/java/HelloWorldJNITest.java b/src/it/jni/src/test/java/HelloWorldJNITest.java
new file mode 100644
index 0000000..683c321
--- /dev/null
+++ b/src/it/jni/src/test/java/HelloWorldJNITest.java
@@ -0,0 +1,25 @@
+import junit.framework.*;
+
+import com.mycompany.mypackage.HelloWorldJNI;
+
+public class HelloWorldJNITest extends TestCase {
+
+ public HelloWorldJNITest(String name) {
+ super(name);
+ }
+
+ protected void setUp() throws Exception {
+ super.setUp();
+ }
+
+ protected void tearDown() throws Exception {
+ super.tearDown();
+ }
+
+ public void testNativeHelloWorldJNI() throws Exception {
+ HelloWorldJNI app = new HelloWorldJNI();
+
+ this.assertEquals( "Hello NAR World!", app.sayHello() );
+ }
+}
+
diff --git a/src/site/apt/HelloWorld.apt b/src/site/apt/HelloWorld.apt
index 7d1f2aa..3a11ce5 100644
--- a/src/site/apt/HelloWorld.apt
+++ b/src/site/apt/HelloWorld.apt
@@ -19,14 +19,14 @@ There are also some unit test which are run and call the same method.
[]
- [helloworldjni] A C routine called from Java and a Java unit test.
+ [jni] A C routine called from Java and a Java unit test.
- [helloworldjnilibjava] A java project which depends on helloworldjni.
+ [helloworldjnilibjava] A java project which depends on "jni".
[helloworldstaticjni] A C routine called from Java statically linked with the C-runtime library and a Java unit test.
[hellothirdpartyjni] A third party JNI library called from Java.
- The third party library is "helloworldjni" and is added as resource to the project in the
+ The third party library is "jni" and is added as resource to the project in the
form of a JNI library and a corresponding jar file. A Java unit test is provided.
[]