forked from apache/geode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
build.gradle
executable file
·425 lines (363 loc) · 13.6 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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
/*
* 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.
*/
import org.gradle.api.internal.artifacts.publish.ArchivePublishArtifact;
apply plugin: 'distribution'
// disable artifact generation for this project
jar.enabled = false
extraArchive {
sources = false
javadoc = false
tests = false
}
disableMavenPublishing()
// Gradle doesn't automatically remove the jar artifact even though we disabled it
// this causes publishing to fail. So we nuke all the disabled artifacts from all configurations.
configurations.all {
artifacts.removeAll artifacts.findAll { it instanceof ArchivePublishArtifact && !it.archiveTask.enabled }
}
gradle.taskGraph.whenReady( { graph ->
tasks.withType(Tar).each { tar ->
tar.compression = Compression.GZIP
tar.extension = 'tar.gz'
}
})
configurations {
bundled {
description 'A dependency that is shipped with geode, but is not required to compile'
}
gfshDependencies
}
dependencies {
provided project(':geode-core')
archives project(':geode-common')
archives project(':geode-json')
archives project(':geode-core')
archives project(':geode-lucene')
archives project(':geode-old-client-support')
archives project(':geode-web')
archives project(':geode-web-api')
archives project(':geode-pulse')
archives project(':geode-wan')
archives project(':geode-cq')
archives project(':geode-rebalancer')
testCompile project(':geode-junit')
testCompile files(project(':geode-core').sourceSets.test.output)
testCompile ('org.springframework:spring-web:' + project.'springframework.version') {
exclude module: 'aopalliance'
exclude module: 'spring-aop'
}
testCompile 'org.apache.httpcomponents:httpclient:' + project.'httpclient.version'
testCompile 'org.apache.httpcomponents:httpcore:' + project.'httpcore.version'
testRuntime files("${System.getProperty('java.home')}/../lib/tools.jar")
testRuntime files("$buildDir/install/${distributions.main.baseName}/lib/geode-dependencies.jar")
gfshDependencies ('org.springframework:spring-web:' + project.'springframework.version'){
exclude module: 'spring-core'
exclude module: 'commons-logging'
}
}
sourceSets {
// need to remove this since we use the dependencies jar out of the install dir
//test.runtimeClasspath -= configurations.provided
}
test {
// test from the actual classpath not the gradle classpath
dependsOn installDist
// @TODO: this doesn't seem to be working need to get basename first.
classpath += files "$buildDir/install/${distributions.main.baseName}/lib/geode-dependencies.jar"
}
tasks.withType(Test){
environment 'GEODE_HOME', "$buildDir/install/${distributions.main.baseName}/lib"
}
task defaultDistributionConfig(type: JavaExec, dependsOn: classes) {
outputs.file file("$buildDir/gemfire.properties")
main 'org.apache.geode.distributed.internal.DefaultPropertiesGenerator'
classpath project(':geode-core').sourceSets.main.runtimeClasspath
workingDir buildDir
doFirst {
buildDir.mkdirs()
}
}
task defaultCacheConfig(type: JavaExec, dependsOn: classes) {
outputs.file file("$buildDir/cache.xml")
main 'org.apache.geode.internal.cache.xmlcache.CacheXmlGenerator'
classpath project(':geode-core').sourceSets.main.runtimeClasspath
workingDir buildDir
doFirst {
buildDir.mkdirs()
}
}
// This closure sets the gemfire classpath. If we add another jar to the classpath it must
// be included in the filter logic below.
def cp = {
// first add all the dependent project jars
def jars = configurations.archives.dependencies.collect { it.dependencyProject }
.findAll { !(it.name.contains('web') || it.name.contains('pulse')) }
.collect { it.jar.archiveName }
.join(' ')
// then add all the dependencies of the dependent jars
jars += ' ' + configurations.archives.dependencies.collect {
it.dependencyProject.findAll { !(it.name.contains('web-api') || it.name.contains('pulse')) }
.collect { it.configurations.runtime.collect { it.getName() }.findAll {
// depedencies from geode-core
it.contains('antlr') ||
it.contains('commons-io') ||
it.contains('commons-lang') ||
it.contains('commons-logging') ||
it.contains('fastutil') ||
it.contains('jackson-annotations') ||
it.contains('jackson-core') ||
it.contains('jackson-databind') ||
it.contains('jansi') ||
it.contains('javax.resource-api') ||
it.contains('javax.servlet-api') ||
it.contains('javax.transaction-api') ||
it.contains('jetty-http') ||
it.contains('jetty-io') ||
it.contains('jetty-security') ||
it.contains('jetty-server') ||
it.contains('jetty-servlet') ||
it.contains('jetty-webapp') ||
it.contains('jetty-util') ||
it.contains('jetty-xml') ||
it.contains('jline') ||
it.contains('jna') ||
it.contains('jopt-simple') ||
it.contains('log4j-api') ||
it.contains('log4j-core') ||
it.contains('log4j-jcl') ||
it.contains('log4j-jul') ||
it.contains('log4j-slf4j-impl') ||
it.contains('shiro') ||
it.contains('slf4j-api') ||
it.contains('spring-core') ||
it.contains('spring-shell') ||
it.contains('snappy') ||
it.contains('jgroups') ||
it.contains('netty') ||
// dependencies from geode-lucene
it.contains('lucene-analyzers-common') ||
it.contains('lucene-core') ||
it.contains('lucene-queries') ||
it.contains('lucene-queryparser')
}
}
}.flatten().unique().join(' ')
return jars
}
// Note: this dependency doesn't work if you change a library version from
// a dependent project. Please fix me.
task depsJar (type: Jar, dependsOn: ':geode-core:classes') {
description 'Assembles the jar archive that defines the gemfire classpath.'
archiveName 'geode-dependencies.jar'
doFirst {
manifest {
attributes("Class-Path": cp())
}
}
}
// Note: this dependency doesn't work if you change a library version from
// a dependent project. Please fix me.
task gfshDepsJar (type: Jar, dependsOn: ':geode-core:classes') {
description 'Assembles the jar archive that defines the gfsh classpath.'
archiveName 'gfsh-dependencies.jar'
doFirst {
manifest {
attributes("Class-Path": cp() +
' ' + project(':geode-core').webJar.archiveName +
' ' + configurations.gfshDependencies.collect{ it.getName() }.flatten().join(' ')
)
}
}
}
def docsDir = file("$buildDir/javadocs")
task docs(type: Javadoc) {
options.addStringOption('Xdoclint:none', '-quiet')
options.encoding='UTF-8'
source parent.subprojects*.javadoc*.source
classpath = files(parent.subprojects*.javadoc*.classpath)
title = "${productName} ${project.version}"
include 'org/apache/geode/**/'
exclude 'org/apache/geode/internal/**/'
exclude 'org/apache/geode/**/internal/**/'
exclude 'org/apache/geode/**/xml/**/'
exclude 'org/apache/geode/distributed/**/util/**/'
exclude 'org/apache/geode/test/**/'
destinationDir = docsDir
doLast {
parent.subprojects.each { project ->
copy {
from project.sourceSets.main.resources.srcDirs
into docsDir
include 'javadoc-images/*'
}
}
}
}
task writeBuildInfo {
def buildInfo = file "$buildDir/.buildinfo"
outputs.file buildInfo
doLast {
buildInfo.getParentFile().mkdirs();
new FileOutputStream(buildInfo).withStream { fos ->
project(':geode-core').readScmInfo().store(fos, '')
}
}
}
gradle.taskGraph.whenReady( { graph ->
tasks.withType(AbstractArchiveTask).findAll {
it.name.toLowerCase().contains("dist")
}.each { archive ->
archive.doLast {
ant.checksum file:"${archive.archivePath}", algorithm:"md5", format: 'MD5SUM'
ant.checksum file:"${archive.archivePath}", algorithm:"sha-256", format: 'MD5SUM', fileext: '.sha256'
}
}
})
distributions {
src {
baseName = 'apache-geode-src'
contents {
from writeBuildInfo
from (rootDir) {
exclude 'KEYS'
exclude '**/gradlew'
exclude '**/gradlew.bat'
exclude '**/gradle/wrapper/gradle-wrapper.jar'
exclude '**/.gradle'
exclude '**/build/**'
exclude 'geode-spark-connector/**/target/**'
exclude 'geode-spark-connector/project/project'
exclude '**/.project'
exclude '**/.classpath'
exclude '**/.settings/**'
exclude '**/build-eclipse/**'
exclude '**/.idea/**'
exclude '**/*.iml'
exclude '**/*.ipr'
exclude '**/*.iws'
exclude '**/.travis.yml'
exclude '**/tags'
//These directories are generated on the jenkins server by gradle
exclude 'caches'
exclude 'daemon'
exclude 'native'
exclude 'wrapper'
}
}
}
main {
baseName = 'apache-geode' //TODO rootProject.name
contents {
duplicatesStrategy 'exclude'
exclude '*.asc'
exclude '*.asc'
exclude '*-sources.jar'
exclude '*-javadoc.jar'
from rootProject.file( 'README.md' )
into ('config') {
from defaultCacheConfig
from defaultDistributionConfig
from (project(':geode-core').sourceSets.main.resources.files.find {
it.name == 'log4j2.xml'
})
}
into ('lib') {
from project(":geode-common").configurations.runtime
from project(":geode-common").configurations.archives.allArtifacts.files
from project(":geode-json").configurations.runtime
from project(":geode-json").configurations.archives.allArtifacts.files
from project(":geode-wan").configurations.runtime
from project(":geode-wan").configurations.archives.allArtifacts.files
from project(":geode-cq").configurations.runtime
from project(":geode-cq").configurations.archives.allArtifacts.files
from project(":geode-core").configurations.runtime
from project(":geode-core").configurations.archives.allArtifacts.files
from project(":geode-lucene").configurations.runtime
from project(":geode-lucene").configurations.archives.allArtifacts.files
from project(":geode-old-client-support").configurations.runtime
from project(":geode-old-client-support").configurations.archives.allArtifacts.files
from project(":geode-rebalancer").configurations.runtime
from project(":geode-rebalancer").configurations.archives.allArtifacts.files
from configurations.bundled
from configurations.gfshDependencies
//These tasks are included as closures (wrapped in {}) because gradle may evaluate
//this CopySpec before it evaluates the geode-core build file.
from { project(":geode-core").webJar }
from { project(":geode-core").raJar }
from { project(":geode-core").jcaJar }
// dependency jars
from depsJar
from gfshDepsJar
}
into ('tools/Extensions') {
from (project(":geode-web").configurations.archives.allArtifacts.files) {
exclude '*.jar'
}
from (project(":geode-web-api").configurations.archives.allArtifacts.files) {
exclude '*.jar'
}
}
into ('javadoc') {
from docs
}
into ('tools/Pulse') {
from (project(":geode-pulse").configurations.archives.allArtifacts.files)
}
into ('tools/Modules') {
from (project(':extensions/geode-modules-assembly').configurations.moduleDistOutputs.files)
}
}
}
}
// Create a configuration closure to configure test targets with the install directory
def dependOnInstalledProduct = {
dependsOn installDist
def install = file("$buildDir/install/${distributions.main.baseName}")
environment ('GEODE_HOME', install)
}
// Add the configuration closure to the test targets so they depend on the install directory
test dependOnInstalledProduct
distributedTest dependOnInstalledProduct
integrationTest dependOnInstalledProduct
flakyTest dependOnInstalledProduct
// Make build final task to generate all test and product resources
build.dependsOn installDist
installDist.dependsOn ':extensions/geode-modules-assembly:dist'
/**Print the names of all jar files in a fileTree */
def printJars(tree) {
tree.matching {include("**/*.jar")}.visit{ file ->
if(!file.isDirectory()) {
println file.name
}
};
}
task dumpInstalledJars(dependsOn: installDist) << {
description "Dump a list of all of the jars shipped with the binary distribution, for validation purposes"
FileTree installDir = fileTree(dir: installDist.destinationDir)
println("Jars in the binary install")
println("==========================")
printJars(installDir)
installDir.include("**/*.war").visit{ file ->
if(!file.isDirectory()) {
FileTree warContents = zipTree(file.file)
println ""
println file.name
println("==========================")
printJars(warContents);
}
};
}