build.gradle 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. buildscript {
  2. repositories {
  3. maven { url "https://repo.spring.io/plugins-release" }
  4. maven { url "https://repo.spring.io/plugins-snapshot" }
  5. }
  6. dependencies {
  7. classpath "com.github.ben-manes:gradle-versions-plugin:0.17.0"
  8. classpath("org.springframework.build.gradle:propdeps-plugin:0.0.7")
  9. classpath("io.spring.gradle:spring-io-plugin:0.0.6.RELEASE")
  10. classpath("com.bmuschko:gradle-tomcat-plugin:2.2.4")
  11. classpath('me.champeau.gradle:gradle-javadoc-hotfix-plugin:0.1')
  12. classpath('org.asciidoctor:asciidoctor-gradle-plugin:1.5.1')
  13. classpath("io.spring.gradle:docbook-reference-plugin:0.3.1")
  14. classpath("org.springframework.boot:spring-boot-gradle-plugin:1.5.2.RELEASE")
  15. }
  16. }
  17. plugins {
  18. id "org.sonarqube" version "2.1-rc1"
  19. }
  20. apply plugin: 'base'
  21. description = 'Spring Security'
  22. allprojects {
  23. apply plugin: 'idea'
  24. apply plugin: 'eclipse'
  25. apply plugin: "com.github.ben-manes.versions"
  26. ext.releaseBuild = version.endsWith('RELEASE')
  27. ext.snapshotBuild = version.endsWith('SNAPSHOT')
  28. ext.springVersion = '4.3.19.RELEASE'
  29. ext.springLdapVersion = '2.3.2.RELEASE'
  30. group = 'org.springframework.security'
  31. repositories {
  32. mavenCentral()
  33. maven { url "https://repo.spring.io/libs-snapshot" }
  34. maven { url "https://repo.spring.io/plugins-release" }
  35. maven { url "http://repo.terracotta.org/maven2/" }
  36. }
  37. }
  38. sonarqube {
  39. properties {
  40. property "sonar.java.coveragePlugin", "jacoco"
  41. property "sonar.projectName", "Spring Security"
  42. property "sonar.jacoco.reportPath", "${buildDir.name}/jacoco.exec"
  43. property "sonar.links.homepage", 'https://www.springsource.org/spring-security'
  44. property "sonar.links.ci", 'https://build.springsource.org/browse/SEC-B32X'
  45. property "sonar.links.issue", 'https://jira.springsource.org/browse/SEC'
  46. property "sonar.links.scm", 'https://github.com/SpringSource/spring-security'
  47. property "sonar.links.scm_dev", 'https://github.com/SpringSource/spring-security.git'
  48. property "sonar.java.coveragePlugin", "jacoco"
  49. }
  50. }
  51. // Set up different subproject lists for individual configuration
  52. ext.javaProjects = subprojects.findAll { project -> project.name != 'docs' && project.name != 'manual' && project.name != 'guides' && project.name != 'spring-security-bom' }
  53. ext.sampleProjects = subprojects.findAll { project -> project.name.startsWith('spring-security-samples') }
  54. ext.itestProjects = subprojects.findAll { project -> project.name.startsWith('itest') }
  55. ext.coreModuleProjects = javaProjects - sampleProjects - itestProjects
  56. ext.aspectjProjects = [project(':spring-security-aspects'), project(':spring-security-samples-xml-aspectj'), project(':spring-security-samples-javaconfig-aspectj')]
  57. configure(allprojects - javaProjects) {
  58. task afterEclipseImport {
  59. ext.srcFile = file('.classpath')
  60. inputs.file srcFile
  61. outputs.dir srcFile
  62. onlyIf { !srcFile.exists() }
  63. doLast {
  64. srcFile << """<?xml version="1.0" encoding="UTF-8"?>
  65. <classpath>
  66. <classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
  67. <classpathentry kind="output" path="bin"/>
  68. </classpath>
  69. """
  70. }
  71. }
  72. }
  73. configure(subprojects - coreModuleProjects - project(':spring-security-samples-javaconfig-messages') - project(':spring-security-bom')) {
  74. tasks.findByPath("artifactoryPublish")?.enabled = false
  75. sonarqube {
  76. skipProject = true
  77. }
  78. }
  79. configure(javaProjects) {
  80. ext.TOMCAT_GRADLE = "$rootDir/gradle/tomcat.gradle"
  81. ext.WAR_SAMPLE_GRADLE = "$rootDir/gradle/war-sample.gradle"
  82. ext.BOOT_SAMPLE_GRADLE = "$rootDir/gradle/boot-sample.gradle"
  83. apply from: "$rootDir/gradle/javaprojects.gradle"
  84. if(!project.name.contains('gae')) {
  85. apply from: "$rootDir/gradle/checkstyle.gradle"
  86. }
  87. apply from: "$rootDir/gradle/ide.gradle"
  88. apply from: "$rootDir/gradle/release-checks.gradle"
  89. apply from: "$rootDir/gradle/maven-deployment.gradle"
  90. }
  91. configure(coreModuleProjects) {
  92. apply plugin: 'emma'
  93. apply plugin: 'spring-io'
  94. ext.springIoVersion = project.hasProperty('platformVersion') ? platformVersion : 'Brussels-SR9'
  95. configurations {
  96. jacoco //Configuration Group used by Sonar to provide Code Coverage using JaCoCo
  97. }
  98. dependencyManagement {
  99. springIoTestRuntime {
  100. imports {
  101. mavenBom("io.spring.platform:platform-bom:${springIoVersion}") {
  102. bomProperties([
  103. 'assertj.version': '2.2.0',
  104. 'mockito.version': '1.10.19'
  105. ])
  106. }
  107. }
  108. }
  109. }
  110. dependencies {
  111. jacoco "org.jacoco:org.jacoco.agent:0.7.9:runtime"
  112. }
  113. test {
  114. jvmArgs "-javaagent:${configurations.jacoco.asPath}=destfile=${buildDir}/jacoco.exec,includes=${project.group}.*"
  115. }
  116. integrationTest {
  117. jvmArgs "-javaagent:${configurations.jacoco.asPath}=destfile=${buildDir}/jacoco.exec,includes=${project.group}.*"
  118. }
  119. }
  120. configure (aspectjProjects) {
  121. apply plugin: 'java'
  122. apply plugin: 'aspectj'
  123. }
  124. task coreBuild {
  125. dependsOn coreModuleProjects*.tasks*.matching { task -> task.name == 'build' }
  126. }
  127. task coreInstall {
  128. dependsOn coreModuleProjects*.tasks*.matching { task -> task.name == 'install' }
  129. }
  130. // Task for creating the distro zip
  131. task dist(type: Zip) {
  132. dependsOn { subprojects*.tasks*.matching { task -> task.name.endsWith('generatePom') } }
  133. classifier = 'dist'
  134. evaluationDependsOn(':docs')
  135. evaluationDependsOn(':docs:manual')
  136. def zipRootDir = "${project.name}-$version"
  137. into(zipRootDir) {
  138. from(rootDir) {
  139. include '*.adoc'
  140. include '*.txt'
  141. }
  142. into('docs') {
  143. with(project(':docs').apiSpec)
  144. with(project(':docs:manual').spec)
  145. with(project(':docs:guides').spec)
  146. }
  147. project.coreModuleProjects*.tasks*.withType(AbstractArchiveTask).flatten().each{ archiveTask ->
  148. if(archiveTask!=dist){
  149. into("$zipRootDir/dist") {
  150. from archiveTask.outputs.files
  151. }
  152. }
  153. }
  154. sampleProjects.each { project->
  155. into("$zipRootDir/samples/$project.name") {
  156. from(project.projectDir) {
  157. include "src/main/**"
  158. include "pom.xml"
  159. }
  160. }
  161. }
  162. }
  163. }
  164. artifacts {
  165. archives dist
  166. archives project(':docs').docsZip
  167. archives project(':docs').schemaZip
  168. }