Skip to content
Snippets Groups Projects
pom.xml 20.2 KiB
Newer Older
  • Learn to ignore specific revisions
  • <?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>
      <groupId>org.spark-project</groupId>
    
      <artifactId>spark-parent</artifactId>
    
      <version>0.8.0-SNAPSHOT</version>
    
      <packaging>pom</packaging>
      <name>Spark Project Parent POM</name>
      <url>http://spark-project.org/</url>
      <licenses>
        <license>
          <name>BSD License</name>
          <url>https://github.com/mesos/spark/blob/master/LICENSE</url>
          <distribution>repo</distribution>
        </license>
      </licenses>
      <scm>
        <connection>scm:git:git@github.com:mesos/spark.git</connection>
        <url>scm:git:git@github.com:mesos/spark.git</url>
      </scm>
      <developers>
        <developer>
          <id>matei</id>
          <name>Matei Zaharia</name>
          <email>matei.zaharia@gmail.com</email>
          <url>http://www.cs.berkeley.edu/~matei</url>
          <organization>U.C. Berkeley Computer Science</organization>
          <organizationUrl>http://www.cs.berkeley.edu/</organizationUrl>
        </developer>
      </developers>
      <issueManagement>
        <system>github</system>
    
        <url>https://spark-project.atlassian.net/browse/SPARK</url>
    
      </issueManagement>
    
      <prerequisites>
        <maven>3.0.0</maven>
      </prerequisites>
    
      <modules>
        <module>core</module>
        <module>bagel</module>
    
        <module>mllib</module>
    
        <module>tools</module>
    
      </modules>
    
      <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    
    
        <java.version>1.5</java.version>
    
        <scala.version>2.9.3</scala.version>
    
    Matei Zaharia's avatar
    Matei Zaharia committed
        <mesos.version>0.12.1</mesos.version>
    
        <akka.version>2.0.3</akka.version>
    
        <slf4j.version>1.7.2</slf4j.version>
    
        <log4j.version>1.2.17</log4j.version>
    
        <hadoop.version>1.2.1</hadoop.version>
        <!-- <hadoop.version>2.0.0-mr1-cdh4.1.2</hadoop.version> -->
    
        <PermGen>64m</PermGen>
    
        <MaxPermGen>512m</MaxPermGen>
    
      </properties>
    
      <repositories>
        <repository>
          <id>jboss-repo</id>
          <name>JBoss Repository</name>
          <url>http://repository.jboss.org/nexus/content/repositories/releases/</url>
          <releases>
            <enabled>true</enabled>
          </releases>
          <snapshots>
            <enabled>false</enabled>
          </snapshots>
        </repository>
        <repository>
          <id>cloudera-repo</id>
          <name>Cloudera Repository</name>
          <url>https://repository.cloudera.com/artifactory/cloudera-repos/</url>
          <releases>
            <enabled>true</enabled>
          </releases>
          <snapshots>
            <enabled>false</enabled>
          </snapshots>
        </repository>
        <repository>
    
          <id>akka-repo</id>
          <name>Akka Repository</name>
          <url>http://repo.akka.io/releases/</url>
    
          <releases>
            <enabled>true</enabled>
          </releases>
          <snapshots>
            <enabled>false</enabled>
          </snapshots>
        </repository>
      </repositories>
      <pluginRepositories>
        <pluginRepository>
          <id>oss-sonatype-releases</id>
          <name>OSS Sonatype</name>
          <url>https://oss.sonatype.org/content/repositories/releases</url>
          <releases>
            <enabled>true</enabled>
          </releases>
          <snapshots>
            <enabled>false</enabled>
          </snapshots>
        </pluginRepository>
        <pluginRepository>
          <id>oss-sonatype-snapshots</id>
          <name>OSS Sonatype</name>
          <url>https://oss.sonatype.org/content/repositories/snapshots</url>
          <releases>
            <enabled>false</enabled>
          </releases>
          <snapshots>
            <enabled>true</enabled>
          </snapshots>
        </pluginRepository>
        <pluginRepository>
          <id>oss-sonatype</id>
          <name>OSS Sonatype</name>
          <url>https://oss.sonatype.org/content/groups/public</url>
          <releases>
            <enabled>true</enabled>
          </releases>
          <snapshots>
            <enabled>true</enabled>
          </snapshots>
        </pluginRepository>
      </pluginRepositories>
    
      <dependencyManagement>
        <dependencies>
          <dependency>
            <groupId>org.eclipse.jetty</groupId>
            <artifactId>jetty-server</artifactId>
            <version>7.5.3.v20111011</version>
          </dependency>
          <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>11.0.1</version>
          </dependency>
          <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>${slf4j.version}</version>
          </dependency>
          <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>${slf4j.version}</version>
          </dependency>
          <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>jul-to-slf4j</artifactId>
            <version>${slf4j.version}</version>
          </dependency>
          <dependency>
            <groupId>com.ning</groupId>
            <artifactId>compress-lzf</artifactId>
            <version>0.8.4</version>
          </dependency>
    
          <dependency>
            <groupId>org.xerial.snappy</groupId>
            <artifactId>snappy-java</artifactId>
            <version>1.0.5</version>
          </dependency>
    
          <dependency>
    
    Matei Zaharia's avatar
    Matei Zaharia committed
            <groupId>org.ow2.asm</groupId>
            <artifactId>asm</artifactId>
            <version>4.0</version>
    
          </dependency>
          <dependency>
            <groupId>com.google.protobuf</groupId>
            <artifactId>protobuf-java</artifactId>
            <version>2.4.1</version>
          </dependency>
          <dependency>
    
    ryanlecompte's avatar
    ryanlecompte committed
            <groupId>com.twitter</groupId>
    
            <artifactId>chill_2.9.3</artifactId>
    
    Matei Zaharia's avatar
    Matei Zaharia committed
            <version>0.3.1</version>
    
    ryanlecompte's avatar
    ryanlecompte committed
          </dependency>
          <dependency>
            <groupId>com.twitter</groupId>
            <artifactId>chill-java</artifactId>
    
    Matei Zaharia's avatar
    Matei Zaharia committed
            <version>0.3.1</version>
    
          </dependency>
          <dependency>
            <groupId>com.typesafe.akka</groupId>
            <artifactId>akka-actor</artifactId>
            <version>${akka.version}</version>
          </dependency>
          <dependency>
            <groupId>com.typesafe.akka</groupId>
            <artifactId>akka-remote</artifactId>
            <version>${akka.version}</version>
          </dependency>
          <dependency>
            <groupId>com.typesafe.akka</groupId>
            <artifactId>akka-slf4j</artifactId>
            <version>${akka.version}</version>
          </dependency>
          <dependency>
            <groupId>it.unimi.dsi</groupId>
            <artifactId>fastutil</artifactId>
            <version>6.4.4</version>
          </dependency>
          <dependency>
            <groupId>colt</groupId>
            <artifactId>colt</artifactId>
            <version>1.2.0</version>
          </dependency>
          <dependency>
            <groupId>com.github.scala-incubator.io</groupId>
    
            <artifactId>scala-io-file_2.9.2</artifactId>
    
            <version>0.4.1</version>
          </dependency>
          <dependency>
            <groupId>org.apache.mesos</groupId>
            <artifactId>mesos</artifactId>
    
            <version>${mesos.version}</version>
    
          </dependency>
    
          <dependency>
            <groupId>io.netty</groupId>
            <artifactId>netty-all</artifactId>
            <version>4.0.0.Beta2</version>
          </dependency>
    
          <dependency>
            <groupId>org.apache.derby</groupId>
            <artifactId>derby</artifactId>
            <version>10.4.2.0</version>
            <scope>test</scope>
          </dependency>
    
    Patrick Wendell's avatar
    Patrick Wendell committed
          <dependency>
            <groupId>net.liftweb</groupId>
            <artifactId>lift-json_2.9.2</artifactId>
            <version>2.5</version>
          </dependency>
    
          <dependency>
            <groupId>com.codahale.metrics</groupId>
            <artifactId>metrics-core</artifactId>
            <version>3.0.0</version>
          </dependency>
          <dependency>
            <groupId>com.codahale.metrics</groupId>
            <artifactId>metrics-jvm</artifactId>
            <version>3.0.0</version>
          </dependency>
    
          <dependency>
            <groupId>com.codahale.metrics</groupId>
            <artifactId>metrics-json</artifactId>
            <version>3.0.0</version>
          </dependency>
    
          <dependency>
            <groupId>org.scala-lang</groupId>
            <artifactId>scala-compiler</artifactId>
            <version>${scala.version}</version>
          </dependency>
          <dependency>
            <groupId>org.scala-lang</groupId>
            <artifactId>jline</artifactId>
            <version>${scala.version}</version>
          </dependency>
    
    Mark Hamstra's avatar
    Mark Hamstra committed
          <dependency>
            <groupId>org.scala-lang</groupId>
            <artifactId>scala-library</artifactId>
            <version>${scala.version}</version>
          </dependency>
          <dependency>
            <groupId>org.scala-lang</groupId>
            <artifactId>scalap</artifactId>
            <version>${scala.version}</version>
          </dependency>
    
          <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>${log4j.version}</version>
          </dependency>
    
    
          <dependency>
            <groupId>org.scalatest</groupId>
            <artifactId>scalatest_${scala.version}</artifactId>
    
            <version>1.9.1</version>
    
            <scope>test</scope>
          </dependency>
    
    Charles Reiss's avatar
    Charles Reiss committed
          <dependency>
            <groupId>org.easymock</groupId>
            <artifactId>easymock</artifactId>
            <version>3.1</version>
            <scope>test</scope>
          </dependency>
    
          <dependency>
            <groupId>org.scalacheck</groupId>
            <artifactId>scalacheck_${scala.version}</artifactId>
    
            <version>1.10.0</version>
    
            <scope>test</scope>
          </dependency>
          <dependency>
            <groupId>com.novocode</groupId>
            <artifactId>junit-interface</artifactId>
            <version>0.8</version>
            <scope>test</scope>
          </dependency>
    
          <dependency>
            <groupId>org.apache.hadoop</groupId>
            <artifactId>hadoop-client</artifactId>
    
            <version>${hadoop.version}</version>
    
            <exclusions>
              <exclusion>
                <groupId>asm</groupId>
                <artifactId>asm</artifactId>
              </exclusion>
            </exclusions>
          </dependency>
    
          <!-- Specify Avro version because Kafka also has it as a dependency -->
          <dependency>
            <groupId>org.apache.avro</groupId>
            <artifactId>avro</artifactId>
            <version>1.7.4</version>
          </dependency>
          <dependency>
            <groupId>org.apache.avro</groupId>
            <artifactId>avro-ipc</artifactId>
            <version>1.7.4</version>
            <exclusions>
              <exclusion>
                <groupId>org.jboss.netty</groupId>
                <artifactId>netty</artifactId>
              </exclusion>
            </exclusions>
          </dependency>
    
        </dependencies>
      </dependencyManagement>
    
      <build>
        <pluginManagement>
          <plugins>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-enforcer-plugin</artifactId>
              <version>1.1.1</version>
              <executions>
                <execution>
                  <id>enforce-versions</id>
                  <goals>
                    <goal>enforce</goal>
                  </goals>
                  <configuration>
                    <rules>
                      <requireMavenVersion>
                        <version>3.0.0</version>
                      </requireMavenVersion>
                      <requireJavaVersion>
    
                        <version>${java.version}</version>
    
                      </requireJavaVersion>
                    </rules>
                  </configuration>
                </execution>
              </executions>
            </plugin>
            <plugin>
              <groupId>org.codehaus.mojo</groupId>
              <artifactId>build-helper-maven-plugin</artifactId>
              <version>1.7</version>
            </plugin>
            <plugin>
              <groupId>net.alchim31.maven</groupId>
              <artifactId>scala-maven-plugin</artifactId>
    
              <executions>
                <execution>
                  <id>scala-compile-first</id>
                  <phase>process-resources</phase>
                  <goals>
                    <goal>compile</goal>
                  </goals>
                </execution>
                <execution>
                  <id>scala-test-compile-first</id>
                  <phase>process-test-resources</phase>
                  <goals>
                    <goal>testCompile</goal>
                  </goals>
                </execution>
                <execution>
                  <id>attach-scaladocs</id>
                  <phase>verify</phase>
                  <goals>
                    <goal>doc-jar</goal>
                  </goals>
                </execution>
              </executions>
              <configuration>
                <scalaVersion>${scala.version}</scalaVersion>
                <recompileMode>incremental</recompileMode>
    
                <useZincServer>true</useZincServer>
    
                <args>
                  <arg>-unchecked</arg>
                  <arg>-optimise</arg>
                </args>
                <jvmArgs>
                  <jvmArg>-Xms64m</jvmArg>
    
                  <jvmArg>-Xmx1024m</jvmArg>
    
                  <jvmArg>-XX:PermSize=${PermGen}</jvmArg>
                  <jvmArg>-XX:MaxPermSize=${MaxPermGen}</jvmArg>
    
                </jvmArgs>
    
                <javacArgs>
                  <javacArg>-source</javacArg>
                  <javacArg>${java.version}</javacArg>
                  <javacArg>-target</javacArg>
                  <javacArg>${java.version}</javacArg>
                </javacArgs>
    
              </configuration>
            </plugin>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-compiler-plugin</artifactId>
              <version>2.5.1</version>
              <configuration>
    
                <source>${java.version}</source>
                <target>${java.version}</target>
    
                <encoding>UTF-8</encoding>
                <maxmem>1024m</maxmem>
              </configuration>
            </plugin>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-surefire-plugin</artifactId>
              <version>2.12.4</version>
              <configuration>
                <!-- Uses scalatest instead -->
                <skipTests>true</skipTests>
              </configuration>
            </plugin>
            <plugin>
              <groupId>org.scalatest</groupId>
              <artifactId>scalatest-maven-plugin</artifactId>
              <version>1.0-M2</version>
              <configuration>
                <reportsDirectory>${project.build.directory}/surefire-reports</reportsDirectory>
                <junitxml>.</junitxml>
    
                <filereports>${project.build.directory}/SparkTestSuite.txt</filereports>
    
                <argLine>-Xms64m -Xmx1024m</argLine>
    
              </configuration>
              <executions>
                <execution>
                  <id>test</id>
                  <goals>
                    <goal>test</goal>
                  </goals>
                </execution>
              </executions>
            </plugin>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-jar-plugin</artifactId>
              <version>2.4</version>
            </plugin>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-antrun-plugin</artifactId>
              <version>1.7</version>
            </plugin>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-shade-plugin</artifactId>
              <version>2.0</version>
            </plugin>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-source-plugin</artifactId>
              <version>2.2.1</version>
              <configuration>
                <attach>true</attach>
              </configuration>
              <executions>
                <execution>
                  <id>create-source-jar</id>
                  <goals>
                    <goal>jar-no-fork</goal>
                  </goals>
                </execution>
              </executions>
            </plugin>
          </plugins>
        </pluginManagement>
    
        <plugins>
          <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-enforcer-plugin</artifactId>
          </plugin>
          <plugin>
            <groupId>org.codehaus.mojo</groupId>
            <artifactId>build-helper-maven-plugin</artifactId>
            <executions>
              <execution>
               <id>add-scala-sources</id>
                <phase>generate-sources</phase>
                <goals>
                  <goal>add-source</goal>
                </goals>
                <configuration>
                  <sources>
                    <source>src/main/scala</source>
                  </sources>
                </configuration>
              </execution>
              <execution>
                <id>add-scala-test-sources</id>
                <phase>generate-test-sources</phase>
                <goals>
                  <goal>add-test-source</goal>
                </goals>
                <configuration>
                  <sources>
                    <source>src/test/scala</source>
                  </sources>
                </configuration>
              </execution>
            </executions>
          </plugin>
          <plugin>
            <groupId>net.alchim31.maven</groupId>
            <artifactId>scala-maven-plugin</artifactId>
          </plugin>
          <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-source-plugin</artifactId>
          </plugin>
        </plugins>
      </build>
    
      <profiles>
    
        <profile>
          <id>hadoop2-yarn</id>
          <properties>
            <hadoop.major.version>2</hadoop.major.version>
    
            <!-- 0.23.* is same as 2.0.* - except hardened to run production jobs -->
    
            <yarn.version>2.0.5-alpha</yarn.version>
    
          </properties>
    
          <repositories>
            <repository>
              <id>maven-root</id>
              <name>Maven root repository</name>
              <url>http://repo1.maven.org/maven2/</url>
              <releases>
                <enabled>true</enabled>
              </releases>
              <snapshots>
                <enabled>false</enabled>
              </snapshots>
            </repository>
          </repositories>
    
          <dependencyManagement>
            <dependencies>
              <!-- TODO: check versions, bringover from yarn branch ! -->
              <dependency>
                <groupId>org.apache.hadoop</groupId>
                <artifactId>hadoop-client</artifactId>
                <version>${yarn.version}</version>
              </dependency>
              <dependency>
                <groupId>org.apache.hadoop</groupId>
                <artifactId>hadoop-yarn-api</artifactId>
                <version>${yarn.version}</version>
              </dependency>
              <dependency>
                <groupId>org.apache.hadoop</groupId>
                <artifactId>hadoop-yarn-common</artifactId>
                <version>${yarn.version}</version>
              </dependency>
    
              <dependency>
                <groupId>org.apache.hadoop</groupId>
                <artifactId>hadoop-yarn-client</artifactId>
                <version>${yarn.version}</version>
              </dependency>
    
              <!-- Specify Avro version because Kafka also has it as a dependency -->
              <dependency>
                <groupId>org.apache.avro</groupId>
                <artifactId>avro</artifactId>
    
              </dependency>
              <dependency>
                <groupId>org.apache.avro</groupId>
                <artifactId>avro-ipc</artifactId>
    
              </dependency>
            </dependencies>
          </dependencyManagement>
        </profile>
    
        <profile>
          <id>assembly</id>
          <activation>
            <activeByDefault>false</activeByDefault>
          </activation>
          <modules>
            <module>assembly</module>
          </modules>
        </profile>
        <profile>
          <id>expensive-modules</id>
          <activation>
            <property>
              <name>!noExpensive</name>
            </property>
          </activation>
          <modules>
            <module>repl-bin</module>
          </modules>
        </profile>
    
      </profiles>
    </project>