2016-12-15 11:44:59 -08:00
|
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
|
|
<!--
|
|
|
|
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. See accompanying LICENSE file.
|
|
|
|
-->
|
|
|
|
<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.hadoop</groupId>
|
|
|
|
<artifactId>hadoop-project</artifactId>
|
2017-09-01 11:53:48 -07:00
|
|
|
<version>3.1.0-SNAPSHOT</version>
|
2016-12-15 11:44:59 -08:00
|
|
|
<relativePath>../../hadoop-project</relativePath>
|
|
|
|
</parent>
|
|
|
|
<artifactId>hadoop-client-check-invariants</artifactId>
|
2017-09-01 11:53:48 -07:00
|
|
|
<version>3.1.0-SNAPSHOT</version>
|
2016-12-15 11:44:59 -08:00
|
|
|
<packaging>pom</packaging>
|
|
|
|
|
|
|
|
<description>Enforces our invariants for the api and runtime client modules.</description>
|
|
|
|
<name>Apache Hadoop Client Packaging Invariants</name>
|
|
|
|
|
|
|
|
<properties>
|
|
|
|
</properties>
|
|
|
|
|
|
|
|
<dependencies>
|
|
|
|
<dependency>
|
|
|
|
<groupId>org.apache.hadoop</groupId>
|
|
|
|
<artifactId>hadoop-client-api</artifactId>
|
|
|
|
</dependency>
|
|
|
|
<dependency>
|
|
|
|
<groupId>org.apache.hadoop</groupId>
|
|
|
|
<artifactId>hadoop-client-runtime</artifactId>
|
|
|
|
</dependency>
|
|
|
|
</dependencies>
|
|
|
|
<build>
|
|
|
|
<plugins>
|
|
|
|
<plugin>
|
|
|
|
<groupId>org.apache.maven.plugins</groupId>
|
|
|
|
<artifactId>maven-enforcer-plugin</artifactId>
|
|
|
|
<dependencies>
|
|
|
|
<dependency>
|
|
|
|
<groupId>org.codehaus.mojo</groupId>
|
|
|
|
<artifactId>extra-enforcer-rules</artifactId>
|
|
|
|
<version>1.0-beta-3</version>
|
|
|
|
</dependency>
|
|
|
|
</dependencies>
|
|
|
|
<executions>
|
|
|
|
<execution>
|
|
|
|
<id>enforce-banned-dependencies</id>
|
|
|
|
<goals>
|
|
|
|
<goal>enforce</goal>
|
|
|
|
</goals>
|
|
|
|
<configuration>
|
|
|
|
<rules>
|
|
|
|
<banTransitiveDependencies>
|
|
|
|
<!--
|
|
|
|
<message>
|
|
|
|
Our client-facing artifacts are not supposed to have additional dependencies
|
|
|
|
and one or more of them do. The output from the enforcer plugin should give
|
|
|
|
specifics.
|
|
|
|
</message>
|
|
|
|
-->
|
|
|
|
<excludes>
|
|
|
|
<!-- annotations is provided, and both artifacts exclude the tools transitive,
|
|
|
|
but enforcer still sees it.
|
|
|
|
-->
|
|
|
|
<exclude>org.apache.hadoop:hadoop-annotations</exclude>
|
|
|
|
<!-- We leave HTrace as an unshaded dependnecy on purpose so that tracing within a JVM will work -->
|
|
|
|
<exclude>org.apache.htrace:htrace-core4</exclude>
|
|
|
|
<!-- Leave slf4j unshaded so downstream users can configure logging. -->
|
|
|
|
<exclude>org.slf4j:slf4j-api</exclude>
|
|
|
|
<!-- Leave commons-logging unshaded so downstream users can configure logging. -->
|
|
|
|
<exclude>commons-logging:commons-logging</exclude>
|
|
|
|
<!-- Leave log4j unshaded so downstream users can configure logging. -->
|
|
|
|
<exclude>log4j:log4j</exclude>
|
|
|
|
</excludes>
|
|
|
|
</banTransitiveDependencies>
|
|
|
|
<banDuplicateClasses>
|
|
|
|
<findAllDuplicates>true</findAllDuplicates>
|
|
|
|
<dependencies>
|
|
|
|
<dependency>
|
|
|
|
<groupId>org.apache.hadoop</groupId>
|
|
|
|
<artifactId>hadoop-annotations</artifactId>
|
|
|
|
<ignoreClasses>
|
|
|
|
<ignoreClass>*</ignoreClass>
|
|
|
|
</ignoreClasses>
|
|
|
|
</dependency>
|
|
|
|
</dependencies>
|
|
|
|
</banDuplicateClasses>
|
|
|
|
</rules>
|
|
|
|
<!-- TODO we need a rule for "we don't have classes that are outside of the org.apache.hadoop package" -->
|
|
|
|
<!-- TODO we need a rule for "the constants in this set of classes haven't been shaded / don't have this prefix"
|
|
|
|
Manually checking the set of Keys that look like packages we relocate:
|
|
|
|
|
|
|
|
cat `find . \( -name '*Keys.java' -o -name '*KeysPublic.java' \) -a -path '*/src/main/*'` | grep -E "\"(io\.|org\.|com\.|net\.)" | grep -v "^package" | grep -v "^import" | grep -v "\"org.apache.hadoop"
|
|
|
|
|
|
|
|
Manually check the set of shaded artifacts to see if the Keys constants have been relocated:
|
|
|
|
|
|
|
|
for clazz in `find . \( -name '*Keys.java' -o -name '*KeysPublic.java' \) -a -path '*/src/main/*'`; do
|
|
|
|
clazz=${clazz#*src/main/java/}
|
|
|
|
clazz="${clazz%.java}"
|
|
|
|
javap -cp hadoop-client-modules/hadoop-client-api/target/hadoop-client-api-3.0.0-alpha2-SNAPSHOT.jar:hadoop-client-modules/hadoop-client-runtime/target/hadoop-client-runtime-3.0.0-alpha2-SNAPSHOT.jar:hadoop-client-modules/hadoop-client-minicluster/target/hadoop-client-minicluster-3.0.0-alpha2-SNAPSHOT.jar \
|
|
|
|
-constants "${clazz//\//.}" | grep "org.apache.hadoop.shaded"
|
|
|
|
done
|
|
|
|
-->
|
|
|
|
</configuration>
|
|
|
|
</execution>
|
|
|
|
</executions>
|
|
|
|
</plugin>
|
|
|
|
</plugins>
|
|
|
|
</build>
|
|
|
|
|
|
|
|
</project>
|
|
|
|
|