build.gradle 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  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.17.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.21.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.sampleBootProjects = subprojects.findAll { project -> project.name.startsWith('spring-security-samples-boot') }
  55. ext.itestProjects = subprojects.findAll { project -> project.name.startsWith('itest') }
  56. ext.coreModuleProjects = javaProjects - sampleProjects - itestProjects
  57. ext.aspectjProjects = [project(':spring-security-aspects'), project(':spring-security-samples-xml-aspectj'), project(':spring-security-samples-javaconfig-aspectj')]
  58. configure(allprojects - javaProjects) {
  59. task afterEclipseImport {
  60. ext.srcFile = file('.classpath')
  61. inputs.file srcFile
  62. outputs.dir srcFile
  63. onlyIf { !srcFile.exists() }
  64. doLast {
  65. srcFile << """<?xml version="1.0" encoding="UTF-8"?>
  66. <classpath>
  67. <classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
  68. <classpathentry kind="output" path="bin"/>
  69. </classpath>
  70. """
  71. }
  72. }
  73. }
  74. configure(subprojects - coreModuleProjects - project(':spring-security-samples-javaconfig-messages') - project(':spring-security-bom')) {
  75. tasks.findByPath("artifactoryPublish")?.enabled = false
  76. sonarqube {
  77. skipProject = true
  78. }
  79. }
  80. configure(javaProjects) {
  81. ext.TOMCAT_GRADLE = "$rootDir/gradle/tomcat.gradle"
  82. ext.WAR_SAMPLE_GRADLE = "$rootDir/gradle/war-sample.gradle"
  83. ext.BOOT_SAMPLE_GRADLE = "$rootDir/gradle/boot-sample.gradle"
  84. apply from: "$rootDir/gradle/javaprojects.gradle"
  85. if(!project.name.contains('gae')) {
  86. apply from: "$rootDir/gradle/checkstyle.gradle"
  87. }
  88. apply from: "$rootDir/gradle/ide.gradle"
  89. apply from: "$rootDir/gradle/release-checks.gradle"
  90. apply from: "$rootDir/gradle/maven-deployment.gradle"
  91. }
  92. configure(coreModuleProjects) {
  93. apply plugin: 'emma'
  94. apply plugin: 'spring-io'
  95. ext.springIoVersion = project.hasProperty('platformVersion') ? platformVersion : 'Brussels-SR9'
  96. configurations {
  97. jacoco //Configuration Group used by Sonar to provide Code Coverage using JaCoCo
  98. }
  99. dependencyManagement {
  100. springIoTestRuntime {
  101. imports {
  102. mavenBom("io.spring.platform:platform-bom:${springIoVersion}") {
  103. bomProperties([
  104. 'assertj.version': '2.2.0',
  105. 'mockito.version': '1.10.19'
  106. ])
  107. }
  108. }
  109. }
  110. }
  111. dependencies {
  112. jacoco "org.jacoco:org.jacoco.agent:0.7.9:runtime"
  113. }
  114. test {
  115. jvmArgs "-javaagent:${configurations.jacoco.asPath}=destfile=${buildDir}/jacoco.exec,includes=${project.group}.*"
  116. }
  117. integrationTest {
  118. jvmArgs "-javaagent:${configurations.jacoco.asPath}=destfile=${buildDir}/jacoco.exec,includes=${project.group}.*"
  119. }
  120. }
  121. configure (aspectjProjects) {
  122. apply plugin: 'java'
  123. apply plugin: 'aspectj'
  124. }
  125. task coreBuild {
  126. dependsOn coreModuleProjects*.tasks*.matching { task -> task.name == 'build' }
  127. }
  128. task coreInstall {
  129. dependsOn coreModuleProjects*.tasks*.matching { task -> task.name == 'install' }
  130. }
  131. // Task for creating the distro zip
  132. task dist(type: Zip) {
  133. dependsOn { subprojects*.tasks*.matching { task -> task.name.endsWith('generatePom') } }
  134. classifier = 'dist'
  135. evaluationDependsOn(':docs')
  136. evaluationDependsOn(':docs:manual')
  137. def zipRootDir = "${project.name}-$version"
  138. into(zipRootDir) {
  139. from(rootDir) {
  140. include '*.adoc'
  141. include '*.txt'
  142. }
  143. into('docs') {
  144. with(project(':docs').apiSpec)
  145. with(project(':docs:manual').spec)
  146. with(project(':docs:guides').spec)
  147. }
  148. project.coreModuleProjects*.tasks*.withType(AbstractArchiveTask).flatten().each{ archiveTask ->
  149. if(archiveTask!=dist){
  150. into("$zipRootDir/dist") {
  151. from archiveTask.outputs.files
  152. }
  153. }
  154. }
  155. sampleProjects.each { project->
  156. into("$zipRootDir/samples/$project.name") {
  157. from(project.projectDir) {
  158. include "src/main/**"
  159. include "pom.xml"
  160. }
  161. }
  162. }
  163. }
  164. }
  165. artifacts {
  166. archives dist
  167. archives project(':docs').docsZip
  168. archives project(':docs').schemaZip
  169. }