| <?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:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://maven.apache.org/POM/4.0.0" |
| xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> |
| |
| <modelVersion>4.0.0</modelVersion> |
| |
| <parent> |
| <groupId>org.apache</groupId> |
| <artifactId>apache</artifactId> |
| <version>23</version> |
| </parent> |
| |
| <artifactId>statefun-parent</artifactId> |
| <groupId>org.apache.flink</groupId> |
| <name>statefun-parent</name> |
| <version>2.3-SNAPSHOT</version> |
| <packaging>pom</packaging> |
| |
| <url>http://flink.apache.org</url> |
| <inceptionYear>2014</inceptionYear> |
| |
| <licenses> |
| <license> |
| <name>The Apache Software License, Version 2.0</name> |
| <url>https://www.apache.org/licenses/LICENSE-2.0.txt</url> |
| <distribution>repo</distribution> |
| </license> |
| </licenses> |
| |
| <scm> |
| <url>https://github.com/apache/flink-statefun</url> |
| <connection>git@github.com:apache/flink-statefun.git</connection> |
| <developerConnection>scm:git:https://gitbox.apache.org/repos/asf/flink-statefun.git</developerConnection> |
| </scm> |
| |
| <modules> |
| <module>statefun-sdk</module> |
| <module>statefun-kafka-io</module> |
| <module>statefun-kinesis-io</module> |
| <module>statefun-examples</module> |
| <module>statefun-flink</module> |
| <module>statefun-quickstart</module> |
| <module>statefun-testutil</module> |
| |
| <!-- |
| Always build the end-to-end tests module last, |
| since the module builds the base Stateful Functions image with the |
| built project artifacts before running the end-to-end tests. |
| --> |
| <module>statefun-e2e-tests</module> |
| </modules> |
| |
| <properties> |
| <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> |
| <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> |
| <java.version>1.8</java.version> |
| <spotbugs.version>3.1.12</spotbugs.version> |
| <spotless-maven-plugin.version>1.20.0</spotless-maven-plugin.version> |
| <auto-service.version>1.0-rc6</auto-service.version> |
| <protobuf.version>3.7.1</protobuf.version> |
| <unixsocket.version>2.3.2</unixsocket.version> |
| <protoc-jar-maven-plugin.version>3.11.1</protoc-jar-maven-plugin.version> |
| <flink.version>1.11.1</flink.version> |
| <scala.binary.version>2.12</scala.binary.version> |
| <root.dir>${rootDir}</root.dir> |
| </properties> |
| |
| <dependencies> |
| <dependency> |
| <groupId>com.google.auto.service</groupId> |
| <artifactId>auto-service-annotations</artifactId> |
| <version>${auto-service.version}</version> |
| </dependency> |
| </dependencies> |
| |
| <profiles> |
| <!-- |
| We're reusing the apache-release build profile defined in the Apache Parent POM, |
| with one exclusion: do not run the source-release-assembly execution goal. |
| We have our own scripts to create the source release, which correctly excludes |
| binaries from distribution tarball. |
| The script can be found under tools/releasing/create_source_release.sh. |
| --> |
| <profile> |
| <id>apache-release</id> |
| <build> |
| <plugins> |
| <plugin> |
| <groupId>org.apache.maven.plugins</groupId> |
| <artifactId>maven-assembly-plugin</artifactId> |
| <dependencies> |
| <dependency> |
| <groupId>org.apache.apache.resources</groupId> |
| <artifactId>apache-source-release-assembly-descriptor</artifactId> |
| <version>1.0.6</version> |
| </dependency> |
| </dependencies> |
| <executions> |
| <execution> |
| <id>source-release-assembly</id> |
| <!-- disable the execution --> |
| <phase>none</phase> |
| </execution> |
| </executions> |
| </plugin> |
| </plugins> |
| </build> |
| </profile> |
| </profiles> |
| |
| <build> |
| <pluginManagement> |
| <plugins> |
| <plugin> |
| <groupId>com.github.os72</groupId> |
| <artifactId>protoc-jar-maven-plugin</artifactId> |
| <version>${protoc-jar-maven-plugin.version}</version> |
| <executions> |
| <!-- Generate src/main/protobuf --> |
| <execution> |
| <id>generate-protobuf-sources</id> |
| <phase>generate-sources</phase> |
| <goals> |
| <goal>run</goal> |
| </goals> |
| <configuration> |
| <includeStdTypes>true</includeStdTypes> |
| <protocVersion>${protobuf.version}</protocVersion> |
| <cleanOutputFolder>true</cleanOutputFolder> |
| <outputDirectory>${basedir}/target/generated-sources/protoc-jar</outputDirectory> |
| </configuration> |
| </execution> |
| |
| <!-- Generate src/test/protobuf --> |
| <execution> |
| <id>generate-protobuf-test-sources</id> |
| <phase>generate-sources</phase> |
| <goals> |
| <goal>run</goal> |
| </goals> |
| <configuration> |
| <includeStdTypes>true</includeStdTypes> |
| <protocVersion>${protobuf.version}</protocVersion> |
| <inputDirectories> |
| <include>src/test/protobuf</include> |
| </inputDirectories> |
| <outputTargets> |
| <outputTarget> |
| <type>descriptor</type> |
| <outputDirectory>${basedir}/target/test-classes</outputDirectory> |
| </outputTarget> |
| <outputTarget> |
| <type>java</type> |
| <outputDirectory>${basedir}/target/generated-test-sources/protoc-jar</outputDirectory> |
| </outputTarget> |
| </outputTargets> |
| </configuration> |
| </execution> |
| </executions> |
| </plugin> |
| </plugins> |
| </pluginManagement> |
| |
| <plugins> |
| <!-- Java compiler --> |
| <plugin> |
| <groupId>org.apache.maven.plugins</groupId> |
| <artifactId>maven-compiler-plugin</artifactId> |
| <version>3.8.1</version> |
| <configuration> |
| <source>8</source> |
| <target>8</target> |
| <annotationProcessorPaths> |
| <path> |
| <groupId>com.google.auto.service</groupId> |
| <artifactId>auto-service</artifactId> |
| <version>${auto-service.version}</version> |
| </path> |
| </annotationProcessorPaths> |
| </configuration> |
| </plugin> |
| |
| <!-- Spotbugs --> |
| <plugin> |
| <groupId>com.github.spotbugs</groupId> |
| <artifactId>spotbugs-maven-plugin</artifactId> |
| <version>${spotbugs.version}</version> |
| <dependencies> |
| <dependency> |
| <groupId>com.github.spotbugs</groupId> |
| <artifactId>spotbugs</artifactId> |
| <version>${spotbugs.version}</version> |
| </dependency> |
| </dependencies> |
| <executions> |
| <execution> |
| <id>analyze-compile</id> |
| <phase>verify</phase> |
| <goals> |
| <goal>check</goal> |
| </goals> |
| </execution> |
| </executions> |
| <configuration> |
| <effort>Max</effort> |
| <threshold>Low</threshold> |
| <excludeFilterFile>${root.dir}/tools/maven/spotbugs-exclude.xml</excludeFilterFile> |
| </configuration> |
| </plugin> |
| |
| |
| <!-- Licence --> |
| <plugin> |
| <groupId>org.apache.rat</groupId> |
| <artifactId>apache-rat-plugin</artifactId> |
| <version>0.13</version> |
| <inherited>false</inherited> |
| <executions> |
| <execution> |
| <phase>verify</phase> |
| <goals> |
| <goal>check</goal> |
| </goals> |
| </execution> |
| </executions> |
| <configuration> |
| <excludes> |
| <!-- Additional files like .gitignore etc.--> |
| <exclude>**/.*/**</exclude> |
| <exclude>**/*.prefs</exclude> |
| <exclude>**/*.log</exclude> |
| <!-- Administrative files in the main trunk. --> |
| <exclude>**/README.md</exclude> |
| <exclude>**/README.zh.md</exclude> |
| <exclude>**/CODE_OF_CONDUCT.md</exclude> |
| <exclude>.github/**</exclude> |
| <!-- IDE files. --> |
| <exclude>**/*.iml</exclude> |
| <!-- Generated content --> |
| <exclude>**/target/**</exclude> |
| <exclude>**/_build/**</exclude> |
| <exclude>docs/page/font-awesome/**</exclude> |
| <exclude>docs/page/js/**</exclude> |
| <exclude>docs/content/page/js/**</exclude> |
| <exclude>docs/content/page/font-awesome/**</exclude> |
| <exclude>docs/Gemfile.lock</exclude> |
| <!-- Generated code --> |
| <exclude>**/generated/**</exclude> |
| <!-- Quickstart archetype test configuration --> |
| <exclude>statefun-quickstart/src/test/resources/projects/testArtifact/goal.txt</exclude> |
| <!-- Bundled license files --> |
| <exclude>**/LICENSE*</exclude> |
| <!-- Python venv --> |
| <exclude>**/venv/**</exclude> |
| </excludes> |
| </configuration> |
| </plugin> |
| |
| <!-- Java code style --> |
| <plugin> |
| <groupId>com.diffplug.spotless</groupId> |
| <artifactId>spotless-maven-plugin</artifactId> |
| <version>${spotless-maven-plugin.version}</version> |
| <configuration> |
| <java> |
| <googleJavaFormat> |
| <version>1.7</version> |
| <style>GOOGLE</style> |
| </googleJavaFormat> |
| <removeUnusedImports/> |
| </java> |
| </configuration> |
| <executions> |
| <execution> |
| <id>spotless-check</id> |
| <phase>verify</phase> |
| <goals> |
| <goal>check</goal> |
| </goals> |
| </execution> |
| </executions> |
| </plugin> |
| |
| <!-- Dependency Enforcer --> |
| <plugin> |
| <groupId>org.apache.maven.plugins</groupId> |
| <artifactId>maven-enforcer-plugin</artifactId> |
| <version>3.0.0-M2</version> |
| <executions> |
| <execution> |
| <id>enforce</id> |
| <configuration> |
| <rules> |
| <dependencyConvergence/> |
| </rules> |
| </configuration> |
| <goals> |
| <goal>enforce</goal> |
| </goals> |
| </execution> |
| </executions> |
| </plugin> |
| |
| <plugin> |
| <groupId>org.commonjava.maven.plugins</groupId> |
| <artifactId>directory-maven-plugin</artifactId> |
| <version>0.1</version> |
| <executions> |
| <execution> |
| <id>directories</id> |
| <goals> |
| <goal>highest-basedir</goal> |
| </goals> |
| <phase>initialize</phase> |
| <configuration> |
| <property>rootDir</property> |
| </configuration> |
| </execution> |
| </executions> |
| </plugin> |
| </plugins> |
| </build> |
| </project> |
| |