-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathbuild.gradle
111 lines (89 loc) · 2.81 KB
/
build.gradle
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
plugins {
id 'java'
id 'com.github.johnrengelman.shadow'
id 'com.diffplug.spotless'
}
allprojects {
group = "io.atomicwire.iso20022hackathon"
version = "0.0.1-SNAPSHOT"
}
def javaMainClass = 'io.atomicwire.iso20022hackathon.AtomicSettlement'
apply from: "${rootDir}/dependencies.gradle"
repositories {
mavenCentral()
}
configurations {
flinkShadowJar
implementation.extendsFrom(flinkShadowJar)
}
dependencies {
// Flink provided
implementation "org.apache.flink:flink-streaming-java:${versions.flink}"
implementation "org.apache.flink:flink-clients:${versions.flink}"
implementation "org.apache.flink:flink-connector-datagen:${versions.flink}"
runtimeOnly "org.apache.flink:flink-runtime-web:${versions.flink}"
// Lombok
annotationProcessor "org.projectlombok:lombok:${versions.lombok}"
compileOnly "org.projectlombok:lombok:${versions.lombok}"
testAnnotationProcessor "org.projectlombok:lombok:${versions.lombok}"
testCompileOnly "org.projectlombok:lombok:${versions.lombok}"
// Logging
implementation "org.slf4j:slf4j-api:${versions.slf4j}"
runtimeOnly "org.apache.logging.log4j:log4j-api:${versions.log4j}"
runtimeOnly "org.apache.logging.log4j:log4j-core:${versions.log4j}"
runtimeOnly "org.apache.logging.log4j:log4j-slf4j-impl:${versions.log4j}"
// Testing
testImplementation "org.assertj:assertj-core:${versions.assertj}"
testImplementation "org.junit.jupiter:junit-jupiter-api:${versions.junit}"
testRuntimeOnly "org.junit.jupiter:junit-jupiter-engine:${versions.junit}"
}
java {
toolchain {
languageVersion = JavaLanguageVersion.of(11)
}
}
shadowJar {
configurations = [project.configurations.flinkShadowJar]
}
spotless {
java {
googleJavaFormat(versions.googleJavaFormat)
toggleOffOn()
licenseHeaderFile "${rootProject.projectDir}/doc/license-header.txt"
}
}
test {
useJUnitPlatform()
}
jar {
manifest {
attributes 'Main-Class': javaMainClass
}
}
// Required for Java 17
final def LOCAL_FLINK_JVM_ARGS = [
'--add-opens', 'java.base/java.util=ALL-UNNAMED',
]
tasks.register('run', JavaExec) {
classpath = sourceSets.main.runtimeClasspath
mainClass = javaMainClass
jvmArgs LOCAL_FLINK_JVM_ARGS
args '--trace', 'true'
}
tasks.register('runUnlimited', JavaExec) {
classpath = sourceSets.main.runtimeClasspath
mainClass = javaMainClass
jvmArgs LOCAL_FLINK_JVM_ARGS
args '--rate', '0', '--parallelism', '0', '--print-throughput', 'true', '--print-latency', 'true'
}
tasks.register('runUnlimited32', JavaExec) {
classpath = sourceSets.main.runtimeClasspath
mainClass = javaMainClass
jvmArgs LOCAL_FLINK_JVM_ARGS
args '--rate', '0', '--parallelism', '12', '--print-throughput', 'true',
'--print-latency', 'true', '--output-freq', '3'
}
wrapper {
gradleVersion = versions.gradle
distributionType = Wrapper.DistributionType.ALL
}