From 886338ff80438b2daea3755f165cc411e39ef560 Mon Sep 17 00:00:00 2001 From: Todd Lipcon Date: Thu, 14 Aug 2014 04:47:20 +0000 Subject: [PATCH] MAPREDUCE-6006. native-task: add native tests to maven and fix bug in pom.xml. Contributed by Binglin Chang. git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/branches/MR-2841@1617877 13f79535-47bb-0310-9956-ffa450edef68 --- .../CHANGES.MAPREDUCE-2841.txt | 3 +- .../hadoop-mapreduce-client-common/pom.xml | 11 ------- .../pom.xml | 16 ++++++++-- .../src/CMakeLists.txt | 4 +++ .../src/main/native/test.sh | 29 ++++++++++++------- hadoop-project/pom.xml | 6 ---- 6 files changed, 38 insertions(+), 31 deletions(-) diff --git a/hadoop-mapreduce-project/CHANGES.MAPREDUCE-2841.txt b/hadoop-mapreduce-project/CHANGES.MAPREDUCE-2841.txt index 462ac8bc2d1..c3c6ab9fbac 100644 --- a/hadoop-mapreduce-project/CHANGES.MAPREDUCE-2841.txt +++ b/hadoop-mapreduce-project/CHANGES.MAPREDUCE-2841.txt @@ -11,4 +11,5 @@ MAPREDUCE-5995. native-task: Revert changes to Text internals (todd) MAPREDUCE-6005. native-task: Fix some valgrind errors (Binglin Chang) MAPREDUCE-5984. native-task: Reuse lz4 sources in hadoop-common (Binglin Chang) MAPREDUCE-5976. native-task: should not fail to build if snappy is missing (Manu Zhang) -MAPREDUCE-5978. native-task: remove test case for not supported codec Bzip2Codec and DefaultCodec (Manu Zhang) \ No newline at end of file +MAPREDUCE-5978. native-task: remove test case for not supported codec Bzip2Codec and DefaultCodec (Manu Zhang) +MAPREDUCE-6006. native-task: add native tests to maven and fix bug in pom.xml (Binglin Chang via todd) diff --git a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-common/pom.xml b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-common/pom.xml index 48db5c87cb4..7ef7d3b038d 100644 --- a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-common/pom.xml +++ b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-common/pom.xml @@ -84,17 +84,6 @@ - - maven-jar-plugin - - - - test-jar - - test-compile - - - diff --git a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/pom.xml b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/pom.xml index 9727800b4eb..bb7d7bbcb1b 100644 --- a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/pom.xml +++ b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/pom.xml @@ -66,7 +66,6 @@ org.apache.hadoop hadoop-mapreduce-client-common - test-jar test @@ -173,7 +172,6 @@ overwrite="true"> - @@ -187,6 +185,20 @@ + + native_tests + test + run + + + + + + + + + + diff --git a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/src/CMakeLists.txt b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/src/CMakeLists.txt index f38021dc3c8..77b6109a70b 100644 --- a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/src/CMakeLists.txt +++ b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/src/CMakeLists.txt @@ -167,10 +167,14 @@ SET(CMAKE_BUILD_WITH_INSTALL_RPATH TRUE) if (${CMAKE_SYSTEM_NAME} MATCHES "Darwin") # macosx does not have -lrt set(NT_DEPEND_LIBRARY dl pthread z ${SNAPPY_LIBRARY} ${JAVA_JVM_LIBRARY}) + set(SYSTEM_MAC TRUE) else (${CMAKE_SYSTEM_NAME} MATCHES "Darwin") set(NT_DEPEND_LIBRARY dl rt pthread z ${SNAPPY_LIBRARY} ${JAVA_JVM_LIBRARY}) + set(SYSTEM_MAC FALSE) endif (${CMAKE_SYSTEM_NAME} MATCHES "Darwin") +configure_file(main/native/test.sh test/test.sh) + add_dual_library(nativetask ${CMAKE_BINARY_DIR}/lz4.c ${D}/cityhash/city.cc diff --git a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/src/main/native/test.sh b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/src/main/native/test.sh index 7310c9d4097..01506e6e8f5 100644 --- a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/src/main/native/test.sh +++ b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-nativetask/src/main/native/test.sh @@ -1,18 +1,25 @@ -#!/bin/bash +#!/bin/sh + +# only do normal tests by default +FILTER="--gtest_filter=-Perf.*" # do all tests -if [ "$1" == "all" ]; then -shift -./nttest $@ -exit $? +if [ "$1" = "all" ]; then + shift + FILTER="" fi # do performance tests only -if [ "$1" == "perf" ]; then -shift -./nttest --gtest_filter=Perf.* $@ -exit $? +if [ "$1" = "perf" ]; then + shift + FILTER="--gtest_filter=Perf.*" +fi + +if [ "${SYSTEM_MAC}" = "TRUE" ]; then + # MACOSX already setup RPATH, no extra help required + ./nttest $FILTER $@ +else + JAVA_JVM_LIBRARY_DIR=`dirname ${JAVA_JVM_LIBRARY}` + LD_LIBRARY_PATH=$JAVA_JVM_LIBRARY_DIR:$LD_LIBRARY_PATH ./nttest $FILTER $@ fi -# do not do performance test by default -./nttest --gtest_filter=-Perf.* $@ diff --git a/hadoop-project/pom.xml b/hadoop-project/pom.xml index 947be867b5d..2dc83dd4f92 100644 --- a/hadoop-project/pom.xml +++ b/hadoop-project/pom.xml @@ -134,12 +134,6 @@ hadoop-mapreduce-client-common ${project.version} - - org.apache.hadoop - hadoop-mapreduce-client-common - ${project.version} - test-jar - org.apache.hadoop hadoop-yarn-api