UNPKG

@atomist/sdm-pack-spring

Version:

Atomist software delivery machine extension pack for Spring and Spring Boot applications

74 lines 3.75 kB
"use strict"; /* * Copyright © 2018 Atomist, Inc. * * Licensed 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. */ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); const automation_client_1 = require("@atomist/automation-client"); const microgrammar_1 = require("@atomist/microgrammar"); const sdm_1 = require("@atomist/sdm"); const gradleCommand_1 = require("../gradleCommand"); /** * Build with Gradle in the local automation client. * This implementation requires Java and maven on the classpath. * Note it is NOT intended for use for multiple organizations. It's OK * for one organization to use inside its firewall, but there is potential * vulnerability in builds of unrelated tenants getting at each others * artifacts. */ function gradleSingleModuleBuilder() { return (goalInvocation) => __awaiter(this, void 0, void 0, function* () { const { configuration, id, progressLog, credentials } = goalInvocation; return configuration.sdm.projectLoader.doWithProject({ credentials, id, readOnly: true }, (p) => __awaiter(this, void 0, void 0, function* () { const propertiesOutput = new sdm_1.StringCapturingProgressLog(); const command = gradleCommand_1.determineGradleCommand(p); yield automation_client_1.spawnAndWatch({ command, args: ["properties"] }, { cwd: p.baseDir }, propertiesOutput); const appName = nameGrammar.firstMatch(propertiesOutput.log).$matched; const version = versionGrammar.firstMatch(propertiesOutput.log).$matched; const buildResult = automation_client_1.spawnAndWatch({ command, args: ["--console=plain", "clean", "build"] }, { cwd: p.baseDir }, progressLog, { errorFinder: (code, signal, l) => l.log.includes("[ERROR]"), }); const rb = new UpdatingBuild(id, yield buildResult); rb.ai = { id, name: appName, version }; rb.deploymentUnitFile = `${p.baseDir}/build/libs/${appName}.jar`; return rb; })); }); } exports.gradleSingleModuleBuilder = gradleSingleModuleBuilder; exports.GradleSingleModuleBuilder = gradleSingleModuleBuilder(); const nameGrammar = microgrammar_1.Microgrammar.fromString("name: ${name}", { name: microgrammar_1.Literal, }); const versionGrammar = microgrammar_1.Microgrammar.fromString("version: ${name}", { name: microgrammar_1.Literal, }); class UpdatingBuild { constructor(repoRef, buildResult) { this.repoRef = repoRef; this.buildResult = buildResult; } get appInfo() { return this.ai; } } //# sourceMappingURL=GradleSingleModuleBuilder.js.map