Mercurial > public > develkit
diff init20.gradle @ 175:c3b7af90d1e4
start init script for gradle version 2.*
author | smith@nwoca.org |
---|---|
date | Fri, 12 Dec 2014 20:59:40 +0000 |
parents | init.gradle@e949e86b570e |
children | e0865f323a60 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/init20.gradle Fri Dec 12 20:59:40 2014 +0000 @@ -0,0 +1,522 @@ +import groovy.sql.Sql + +final GradleVersion gradleCurrent = GradleVersion.current() +final GradleVersion gradleV20 = GradleVersion.version('2.0') +println "Gradle Version: $gradleCurrent" +if (gradleCurrent < gradleV20) { + throw new RuntimeException("this init script requires Gradle version 2.0 or higher") +} + +gradle.ext.ssdtDevelkitLocation = gradle.ext.has('ssdtDevelkitLocation') ? gradle.ssdtDevelkitLocation : 'http://hg.ssdt-ohio.org/browse/public/develkit' + +ant.property(file: System.getProperty('user.home') + "/.ssdt/private.properties") +gradle.ext.ivyUserDir = ant.properties['ivy.default.ivy.user.dir'] ?: System.getProperty('user.home') + "/.ivy2" + +gradle.ext.ssdtProjectId = System.getenv('bamboo_project_id') ?: rootProject.name + +gradle.addListener(new ArtifactoryGradleSettings()) + +def hostname +try { + hostname = "hostname".execute().text.toLowerCase().readLines().first() +} catch (e) { + hostname = 'unknown' +} + +gradle.ext.bambooBuild = System.getenv().any { + it.key.toLowerCase().contains('bamboo') +} || hostname?.startsWith('ssdt-') + +gradle.ext.bambooPlan = (System.getenv('BAMBOO_PLAN') ?: 'UNKNOWN-UNKNOWN-JOB1').split('-')[0..1].join('-') +logger.info "Bamboo plan: ${gradle.bambooPlan}" + +gradle.ext.buildTimestamp = System.currentTimeMillis().toString().padLeft(14, '0') + +gradle.ext.hgRepositoryUrl = "" +try { + gradle.ext.hgRepositoryUrl = ("hg path".execute().text.split('=') ?: ['', ''])[1].trim() +} catch (e) { +} + +def springModuleTranslator = [ + 'spring-transaction': 'spring-tx', + 'spring-web-servlet': 'spring-webmvc', +].withDefault { it } + +gradle.ext.normalizeSpring = { DependencyResolveDetails details -> + if (details.requested.group == 'org.springframework' && details.requested.name.startsWith('org.springframework.')) { + def shortName = springModuleTranslator[details.requested.name.replace('org.springframework.', 'spring-').replace('.', '-')] + details.useTarget(group: 'org.springframework', name: shortName, version: details.requested.version) + } + if (details.requested.group == 'org.springframework.security' && details.requested.name.startsWith('org.springframework.')) { + def shortName = springModuleTranslator[details.requested.name.replace('org.springframework.', 'spring-').replace('.', '-')] + details.useTarget("${details.requested.group}:$shortName:${details.requested.version}") + } +} + + +gradle.ext.branchName = System.getenv('bamboo_planRepository_branch') +gradle.ext.branchStream = "" + +if (!gradle.branchName) { + gradle.ext.branchName = "hg branch".execute().text.trim() + def rawParents = 'hg parents'.execute().text + def parent = rawParents.split('\n').find { it.startsWith("branch") }?.split(":")?.getAt(1)?.trim() + gradle.ext.branchName = parent ?: gradle.branchName +} + +if (file('.hgflow').exists()) { + def flows = new Properties() + flows.load(file('.hgflow').newReader()) + flows.stringPropertyNames().each { + if (!it.startsWith("[") && gradle.branchName.startsWith(flows.getProperty(it))) { + gradle.ext.branchStream = it + } + } +} + +gradle.branchName = gradle.branchName.replace('@', '-') +gradle.ext.branchHash = generateMD5(gradle.branchName) +loadEnvironments() + +gradle.environment.put('hgRepositoryUrl', gradle.hgRepositoryUrl) +gradle.environment.put('branchName', gradle.branchName) +gradle.environment.put('branchStream', gradle.branchStream) +gradle.environment.put('branchHash', gradle.branchHash) + + +rootProject.ext.indyCapable = { + boolean capable = true + try { + Class.forName('java.lang.invoke.MethodHandle') + } catch (e) { + capable = false + } + capable && !rootProject.hasProperty('skipIndy') +} + +rootProject.ext.useIndy = { + boolean indy = false + // first, check if a system property activates indy support + indy |= System.hasProperty('indy') && Boolean.valueOf(System.getProperty('indy')) + + // check ssdt environment for indy property. + indy |= (gradle.environment.indy) ? gradle.environment.indy.toBoolean() : false + + // check if the main project has an extension property setting indy (-Pindy). + if (rootProject.hasProperty('indy')) { + indy = (Boolean.valueOf(rootProject.indy)) + } + + // set the groovy runtime system property to ensure forked junit test will get the indy flag properly + if (indy && rootProject.indyCapable()) System.setProperty("groovy.target.indy", "true") + + indy && rootProject.indyCapable() +} + +println "Indy available: ${rootProject.indyCapable()} enabled: ${rootProject.useIndy()}" + +if (gradle.bambooBuild) { + gradle.ext.ssdtGradlekitLocation = gradle.ext.has('ssdtGradlekitLocation') ? gradle.ssdtGradlekitLocation : 'http://hg.ssdt-ohio.org/ssdt/gradlekit/raw-file/tip' + logger.info "applying SSDT artifactory Gradle Settings (bamboo: $gradle.bambooBuild host: $hostname)" + apply from: "${gradle.ssdtGradlekitLocation}/artifactory.gradle" +} + + +buildscript { + repositories { + maven { url 'http://repos.ssdt.nwoca.org/artifactory/ssdt-repo' } + } +} + +apply from: "${gradle.ssdtDevelkitLocation}/metrics.gradle" + +task wrapper(type: Wrapper) {} + +rootProject.afterEvaluate { r -> + + if (r.plugins.hasPlugin(org.gradle.plugins.ide.idea.IdeaPlugin)) { + + r.idea.project.ipr.withXml { xml -> + if (file('.hg').exists()) { + println 'enabling HG on project' + def vcs = findComponent(xml.asNode(), 'VcsDirectoryMappings') + vcs.mapping.@vcs = 'hg4idea' + } + + def codeStyle = findComponent(xml.asNode(), 'ProjectCodeStyleSettingsManager') + if (codeStyle) { + xml.asNode().remove(codeStyle) + } + + def styleManager = xml.asNode().appendNode('component', [name: 'ProjectCodeStyleSettingsManager']) + styleManager.appendNode 'option', [name: 'USE_PER_PROJECT_SETTINGS', value: true] + + def styleOptions = new NodeBuilder().option(name: 'PER_PROJECT_SETTINGS') { + value { + GroovyCodeStyleSettings { + option(name: 'CLASS_COUNT_TO_USE_IMPORT_ON_DEMAND', value: '10') + option(name: 'PACKAGES_TO_USE_IMPORT_ON_DEMAND') { + value { + 'package'(name: "java.awt", withSubpackages: false, static: false) + 'package'(name: "javax.swing", withSubpackages: false, static: false) + 'package'(name: "javax.persistence", withSubpackages: false, static: false) + 'package'(name: "javax.validation", withSubpackages: true, static: false) + } + } + } + XML { + option(name: 'XML_LEGACY_SETTINGS_IMPORTED', value: true) + } + + } + } + + styleManager.append styleOptions + + if (r.group.contains('org.ssdt')) { + + def copyRight = findComponent(xml.asNode(), 'CopyrightManager') + if (copyRight) { + xml.asNode().remove(copyRight) + } + + copyRight = new NodeBuilder().component(name: 'CopyrightManager', default: 'ODE') { + + copyright { + option(name: 'notice', value: 'Copyright (c) $today.year. Ohio Department of Education. - All Rights Reserved.\nUnauthorized copying of this file, in any medium, is strictly prohibited.\nWritten by State Software Development Team (http://ssdt.oecn.k12.oh.us/)') + option(name: 'keyword', value: 'Copyright') + option(name: 'allowReplaceKeyword', value: 'South Front') + option(name: 'myName', value: 'ODE') + option(name: 'myLocal', value: true) + } + LanguageOptions(name: 'CSS') { + option(name: 'fileTypeOverride', value: 1) + } + LanguageOptions(name: 'JSP') { + option(name: 'fileTypeOverride', value: 1) + option(name: 'prefixLines', value: false) + } + LanguageOptions(name: 'JSPX') { + option(name: 'fileTypeOverride', value: 1) + option(name: 'prefixLines', value: false) + } + LanguageOptions(name: 'JavaScript') { + option(name: 'fileTypeOverride', value: 1) + } + LanguageOptions(name: 'Properties') { + option(name: 'fileTypeOverride', value: 1) + } + } + + xml.asNode().append copyRight + + } + } + } + +} + +def findComponent(project, name) { + project.component.find { it.@name == name } +} + +allprojects { + + task cleanLocal(description: "removes all artifacts from developer's local repository") << { + + def local = project.repositories.find { it.name == 'local' } + if (local) { + logger.info "removing local repo: $it" + new File(System.properties['user.home'] + "/.ssdt/local-repo").deleteDir() + def localDir = new File(gradle.ivyUserDir + "/local") + localDir.deleteDir() + logger.info "verifying removal of local repo" + if (localDir.exists()) { + throw new org.gradle.api.GradleException("Unable to clean ${localDir}. Files may be locked by another process.") + } + } + } + + cleanLocal.onlyIf { + project.repositories.any { it.name == 'local' } + } + + tasks.addRule("Pattern: <environment>As[Test]Properties: Generates <environment>.properties as resource or Test resource") { String taskName -> + if ((taskName - 'Test').endsWith("AsProperties") && !taskName.startsWith('clean')) { + def t = taskName.contains('Test') ? processTestResources.destinationDir : processResources.destinationDir + def e = (taskName - 'Test' - 'AsProperties').capitalize() + task(taskName) { + ext.propertyFile = new File(t, "${e.toLowerCase()}.properties") + inputs.files "../environment${e}.groovy", "../private${e}.groovy", '../private.properties' + doLast { + t.mkdirs() + def ps = gradle."environment${e}".toProperties() + ps['ssdt.project'] = project.name + ps.store(propertyFile.newOutputStream(), "by $taskName of $this") + def l = propertyFile.readLines().sort() + propertyFile.text = l.join('\n') + } + } + } + } + + if (gradle.hasProperty('environmentDatabase')) { + tasks.addRule("Pattern: database{Drop|Create}...: drops or creates the environment's database") { String taskName -> + if (taskName.startsWith('database') && (taskName.contains('Drop') || taskName.contains('Create'))) { + task(taskName) { + doLast { + def dropIt = taskName.contains("Drop") + def createIt = taskName.contains("Create") + def driverName = gradle.environmentDatabase.jdbc.driverClassName + def databaseUrl = gradle.environmentDatabase.jdbc.url + if (driverName != "org.postgresql.Driver") { + logger.info "skipping database operation for non-postgresql driver" + throw new StopActionException("driver $driverName not supported by $taskName") + } + if (!configurations.hasProperty('jdbcdriver')) { + throw new GradleException("databaseDrop requires a 'jdbcdriver' configuration with a postgresql (or other) driver") + } + configurations.jdbcdriver.each { File file -> + GroovyObject.class.classLoader.addURL(file.toURL()) + } + Class.forName(driverName) + def url = new URI(databaseUrl.substring(5)) + def jdbcBaseUrl = databaseUrl - url.path + def databaseName = url.path - "/" + def adminUrl = jdbcBaseUrl + "/postgres" + def sql = Sql.newInstance(adminUrl, + gradle.environmentDatabase.jdbc.username, + gradle.environmentDatabase.jdbc.password, + driverName) + if (dropIt) { + logger.info "dropping $databaseName (if exists) from $adminUrl" + sql.execute 'DROP DATABASE IF EXISTS "' + databaseName + '";' + } + + if (createIt) { + logger.info "Creating database $databaseName at $adminUrl" + sql.execute 'CREATE DATABASE "' + databaseName + '";' + } + } + } + + } + } + } + +} + + +class ArtifactoryGradleSettings extends BuildAdapter implements BuildListener { + + def void projectsEvaluated(Gradle gradle) { + def ssdtArtifactory = 'http://repos.ssdt.nwoca.org/artifactory' + Project root = gradle.getRootProject() + root.allprojects { + + + def thisProject = delegate + thisProject.status = 'integration' + if (gradle.branchStream) { + thisProject.status = 'integration' + def fixupVersion = thisProject.version - ".SNAPSHOT" + if (gradle.branchStream == 'feature') { + fixupVersion = fixupVersion + ".SNAPSHOT" + } + if (gradle.branchStream == 'develop') { + fixupVersion = fixupVersion + ".SNAPSHOT" + } + if (gradle.branchStream in ['production', 'release']) { + thisProject. + status = 'release' + } + thisProject + .version = fixupVersion + } + + configurations.all { + resolutionStrategy.cacheChangingModulesFor 60 * 60 * 8, 'seconds' + resolutionStrategy.cacheDynamicVersionsFor 60 * 60 * 8, 'seconds' + } + repositories { + + if (!gradle.bambooBuild) { + ivy { + name = 'local' + artifactPattern gradle.ivyUserDir + '/local/[artifact]-[revision](-[classifier]).[ext]' + ivyPattern gradle.ivyUserDir + "/local/[module]-ivy-[revision].xml" + } + } + + if (gradle.branchStream == 'feature') { + ivy { + name = 'ssdt-branches' + def url = "${ssdtArtifactory}/ssdt-branches" + artifactPattern "${url}/${gradle.branchHash}/[organization]/[module]/[revision]/[module]-[revision](-[classifier]).[ext]" + ivyPattern "${url}/${gradle.branchHash}/[organization]/[module]/ivy-[revision].xml" +// m2compatible = false +// def filter1 = ";ssdt-branch.branchName+=${gradle.branchName.replaceAll('/', '-')}" +// def filter2 = ";ssdt-branch.branchName=${gradle.branchName.replaceAll('/', '-')}" +// checkmodified = true +// changingMatcher = 'regexp' +// changingPattern = '.*SNAPSHOT' + } + } + + ivy { + name = 'ssdt-snapshots' + def url = "${ssdtArtifactory}/ssdt-snapshots" + artifactPattern "${url}/[organization]/[module]/[revision]/[module]-[revision](-[classifier]).[ext]" + artifactPattern "${url}/[organization]/[module]/[revision]/[artifact]-[revision](-[classifier]).[ext]" + ivyPattern "${url}/[organization]/[module]/ivy-[revision].xml" +// checkmodified = true +// m2compatible = true +// changingMatcher = 'regexp' +// changingPattern = '.*SNAPSHOT' + } + + ivy { + name = 'ssdt-releases' +// m2compatible = false + def url = "${ssdtArtifactory}/ssdt-releases" + artifactPattern "${url}/[organization]/[module]/[revision]/[module]-[revision](-[classifier]).[ext]" + artifactPattern "${url}/[organization]/[module]/[revision]/[artifact]-[revision](-[classifier]).[ext]" + ivyPattern("${url}/[organization]/[module]/ivy-[revision].xml") + } + + maven { + name = 'ssdt-repository' + url = "${ssdtArtifactory}/repository" + } + + + } + + if (thisProject.repositories.find { + it.name == 'local' + } && thisProject.getTasksByName('uploadArchives', false)) { + uploadArchives { + repositories { + add thisProject.repositories.local + } + } + + thisProject.tasks.create("publishLocal") { + description = "Publishes this projects artifacts to developer's local repository" + dependsOn = ["uploadArchives"] + } + } + + } + + root.subprojects { p -> + if (root.useIndy()) { + def groovyIndy = p.configurations.compile.files.find { f -> f.name.startsWith('groovy-all') && f.name.contains('-indy') } + if (groovyIndy) { + logger.info "enabling indy on $p" + [compileGroovy.groovyOptions, compileTestGroovy.groovyOptions]*.with { + optimizationOptions = [indy: true] + } + } + } + } + } +} + + +task showEnvironments << { + println "Defined environments: $gradle.environments" + gradle.environments.each { e -> + println "\n $e:" + gradle.getProperty(e).flatten().sort { it.key }.each { k, v -> + println String.format(' %25s = %s', k, k.contains('password') ? "********" : v) + } + } + if (logger.isInfoEnabled()) { + println "System properties:" + System.properties.each { println " $it" } + println "env variables:" + System.getenv().each { println " $it" } + } +} + +def loadEnvironments() { + def developerPrivate = new Properties() + if (file('private.properties').exists()) { + developerPrivate.load(file('private.properties').newReader()) + } + def envOverrides = [:] + + if (!hasProperty('env')) { + gradle.ext.env = developerPrivate.env ?: 'dev' + } else { + def values = getProperty('env').split(',') + gradle.ext.env = values.first() + values.tail().each { + def (k, v) = it.split('=') + envOverrides.put(k, v) + } + } + + println "Environment is: $gradle.env ($envOverrides)" + def slurper = new ConfigSlurper(gradle.env) + slurper.setBinding(['gradle': gradle]) + + def environment = slurper.parse( + '''deploy.mode="production" + environments { + test { deploy.mode="test" } + dev { deploy.mode="development"} + }''') + if (developerPrivate['deploy.mode']) { + environment.put('deploy.mode', developerPrivate['deploy.mode']) + } + + def environments = [] + gradle.ext.environment = environment + file('.').listFiles().findAll { it.name ==~ /^environment.*\.groovy$/ }.sort { it.name }.each { envFile -> + def envName = envFile.name - '.groovy' + def privateFile = file("private" + envName - "environment" + ".groovy") + logger.info("loading environment $envFile.name") + + def envCfg = slurper.parse(envFile.toURL()) + envCfg.merge(slurper.parse(developerPrivate)) + envCfg.put('ssdt.projectid', gradle.ssdtProjectId) + envCfg.put('ssdt.environment', gradle.env) + if (privateFile.exists()) { + logger.info("loading private environment $privateFile") + envCfg.merge(slurper.parse(privateFile.toURL())) + } + + gradle.rootProject.getProperties().find { it.key.startsWith('environment') }.each { + it.value.split(',').each { p -> + def (k, v) = p.split('=') + logger.info("$envName: overriding " + k + "=" + v + " in $it") + envCfg.put(k, v) + } + } + + envOverrides.each { k, v -> + logger.info("$envName: overriding " + k + "=" + v) + envCfg.put(k, v) + } + environment.merge(envCfg) + if (envName != 'environment') { + gradle.ext[envName] = envCfg + environments << envName + } + } + environment.merge(slurper.parse(developerPrivate)) + def deployMode = environment.deploy.mode ?: 'development' + environments.each { gradle.ext[it].put('ssdt.deployment.mode', deployMode) } + environments << 'environment' + gradle.ext.environments = environments + +} + +def generateMD5(String s) { + def digest = java.security.MessageDigest.getInstance("MD5") + digest.update(s.bytes); + new BigInteger(1, digest.digest()).toString(16).padLeft(32, '0') +} \ No newline at end of file