UNPKG

@sasjs/cli

Version:

Command line interface for SASjs

572 lines (571 loc) 32.6 kB
"use strict"; var __assign = (this && this.__assign) || function () { __assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } 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) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; var __generator = (this && this.__generator) || function (thisArg, body) { var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; function verb(n) { return function (v) { return step([n, v]); }; } function step(op) { if (f) throw new TypeError("Generator is already executing."); while (g && (g = 0, op[0] && (_ = 0)), _) try { if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; if (y = 0, t) op = [op[0] & 2, t.value]; switch (op[0]) { case 0: case 1: t = op; break; case 4: _.label++; return { value: op[1], done: false }; case 5: _.label++; y = op[1]; op = [0]; continue; case 7: op = _.ops.pop(); _.trys.pop(); continue; default: if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } if (t[2]) _.ops.pop(); _.trys.pop(); continue; } op = body.call(thisArg, _); } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; } }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.compileJobsServicesTests = exports.copyFilesToBuildFolder = exports.compile = void 0; var utils_1 = require("@sasjs/utils"); var types_1 = require("@sasjs/utils/types"); var error_1 = require("@sasjs/utils/error"); var path_1 = __importDefault(require("path")); var config_1 = require("../../utils/config"); var file_1 = require("../../utils/file"); var web_1 = require("../web/web"); var compileModule = __importStar(require("./compile")); var internal_1 = require("./internal"); function compile(target, forceCompile) { var _a, _b; if (forceCompile === void 0) { forceCompile = false; } return __awaiter(this, void 0, void 0, function () { var result, compileTree, macroFolders, programFolders_1, buildMacroTestFolder_1, macroTestFiles; var _this = this; return __generator(this, function (_c) { switch (_c.label) { case 0: return [4 /*yield*/, (0, internal_1.checkCompileStatus)(target, ['tests']) // no need to compile again ]; case 1: result = _c.sent(); // no need to compile again if (result.compiled && !forceCompile) { (_a = process.logger) === null || _a === void 0 ? void 0 : _a.info('Skipping compilation.'); (_b = process.logger) === null || _b === void 0 ? void 0 : _b.info(result.message); return [2 /*return*/]; } return [4 /*yield*/, compileModule.copyFilesToBuildFolder(target).catch(function (error) { var _a; (_a = process.logger) === null || _a === void 0 ? void 0 : _a.error('Project compilation has failed.'); throw error; })]; case 2: _c.sent(); compileTree = (0, internal_1.getCompileTree)(target); return [4 /*yield*/, compileModule.compileJobsServicesTests(target, compileTree)]; case 3: _c.sent(); return [4 /*yield*/, (0, config_1.getMacroFolders)(target)]; case 4: macroFolders = _c.sent(); if (!macroFolders.length) return [3 /*break*/, 11]; return [4 /*yield*/, (0, config_1.getProgramFolders)(target)]; case 5: programFolders_1 = _c.sent(); return [4 /*yield*/, (0, utils_1.asyncForEach)(macroFolders, function (macroFolder) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, (0, internal_1.copyTestMacroFiles)(macroFolder)]; case 1: return [2 /*return*/, _a.sent()]; } }); }); })]; case 6: _c.sent(); buildMacroTestFolder_1 = path_1.default.join(process.sasjsConstants.buildDestinationTestFolder, 'macros'); return [4 /*yield*/, (0, utils_1.folderExists)(buildMacroTestFolder_1)]; case 7: if (!_c.sent()) return [3 /*break*/, 11]; return [4 /*yield*/, (0, utils_1.listFilesAndSubFoldersInFolder)(buildMacroTestFolder_1)]; case 8: return [4 /*yield*/, (_c.sent()).filter(file_1.isSasFile)]; case 9: macroTestFiles = _c.sent(); return [4 /*yield*/, (0, utils_1.asyncForEach)(macroTestFiles, function (macroTestFile) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, (0, internal_1.compileFile)(target, path_1.default.join(buildMacroTestFolder_1, macroTestFile), macroFolders, programFolders_1, undefined, compileTree, types_1.SASJsFileType.service, '')]; case 1: return [2 /*return*/, _a.sent()]; } }); }); })]; case 10: _c.sent(); _c.label = 11; case 11: return [4 /*yield*/, compileTree.saveTree()]; case 12: _c.sent(); return [4 /*yield*/, (0, internal_1.compileTestFlow)(target).catch(function (err) { var _a; return (_a = process.logger) === null || _a === void 0 ? void 0 : _a.error('Test flow compilation has failed.'); })]; case 13: _c.sent(); return [4 /*yield*/, compileWeb(target)]; case 14: _c.sent(); return [4 /*yield*/, syncFolder(target)]; case 15: _c.sent(); return [2 /*return*/]; } }); }); } exports.compile = compile; function copyFilesToBuildFolder(target) { var _a, _b; return __awaiter(this, void 0, void 0, function () { var buildDestinationFolder, serviceFolders, jobFolders, error_2; var _this = this; return __generator(this, function (_c) { switch (_c.label) { case 0: buildDestinationFolder = process.sasjsConstants.buildDestinationFolder; return [4 /*yield*/, recreateBuildFolder()]; case 1: _c.sent(); (_a = process.logger) === null || _a === void 0 ? void 0 : _a.info("Copying files to ".concat(buildDestinationFolder, " .")); _c.label = 2; case 2: _c.trys.push([2, 7, , 8]); return [4 /*yield*/, (0, internal_1.getAllFolders)(target, internal_1.SasFileType.Service)]; case 3: serviceFolders = _c.sent(); return [4 /*yield*/, (0, internal_1.getAllFolders)(target, internal_1.SasFileType.Job) // REFACTOR ]; case 4: jobFolders = _c.sent(); // REFACTOR return [4 /*yield*/, (0, utils_1.asyncForEach)(serviceFolders, function (serviceFolder) { return __awaiter(_this, void 0, void 0, function () { var destinationPath; return __generator(this, function (_a) { switch (_a.label) { case 0: destinationPath = (0, internal_1.getDestinationServicePath)(serviceFolder); return [4 /*yield*/, (0, utils_1.copy)(serviceFolder, destinationPath)]; case 1: _a.sent(); return [2 /*return*/]; } }); }); })]; case 5: // REFACTOR _c.sent(); return [4 /*yield*/, (0, utils_1.asyncForEach)(jobFolders, function (jobFolder) { return __awaiter(_this, void 0, void 0, function () { var destinationPath; return __generator(this, function (_a) { switch (_a.label) { case 0: destinationPath = (0, internal_1.getDestinationJobPath)(jobFolder); return [4 /*yield*/, (0, utils_1.copy)(jobFolder, destinationPath)]; case 1: _a.sent(); return [2 /*return*/]; } }); }); })]; case 6: _c.sent(); return [3 /*break*/, 8]; case 7: error_2 = _c.sent(); (_b = process.logger) === null || _b === void 0 ? void 0 : _b.error("An error has occurred when copying files to ".concat(buildDestinationFolder, " .")); throw error_2; case 8: return [2 /*return*/]; } }); }); } exports.copyFilesToBuildFolder = copyFilesToBuildFolder; function compileJobsServicesTests(target, compileTree) { return __awaiter(this, void 0, void 0, function () { var serviceFolders, jobFolders, macroFolders_1, programFolders_2, testSetUp, testTearDown, error_3; var _this = this; return __generator(this, function (_a) { switch (_a.label) { case 0: _a.trys.push([0, 13, , 14]); return [4 /*yield*/, (0, internal_1.getAllFolders)(target, internal_1.SasFileType.Service)]; case 1: serviceFolders = _a.sent(); return [4 /*yield*/, (0, internal_1.getAllFolders)(target, internal_1.SasFileType.Job)]; case 2: jobFolders = _a.sent(); return [4 /*yield*/, (0, config_1.getMacroFolders)(target)]; case 3: macroFolders_1 = _a.sent(); return [4 /*yield*/, (0, config_1.getProgramFolders)(target)]; case 4: programFolders_2 = _a.sent(); return [4 /*yield*/, (0, config_1.getTestSetUp)(target)]; case 5: testSetUp = _a.sent(); return [4 /*yield*/, (0, config_1.getTestTearDown)(target)]; case 6: testTearDown = _a.sent(); if (!testSetUp) return [3 /*break*/, 8]; return [4 /*yield*/, (0, internal_1.compileTestFile)(target, testSetUp, '', true, false, compileTree).catch(function (err) { throw (0, error_1.prefixMessage)(err, 'Test set up compilation has failed. '); })]; case 7: _a.sent(); _a.label = 8; case 8: if (!testTearDown) return [3 /*break*/, 10]; return [4 /*yield*/, (0, internal_1.compileTestFile)(target, testTearDown, '', true, false, compileTree).catch(function (err) { throw (0, error_1.prefixMessage)(err, 'Test tear down compilation has failed. '); })]; case 9: _a.sent(); _a.label = 10; case 10: return [4 /*yield*/, (0, utils_1.asyncForEach)(serviceFolders, function (serviceFolder) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, compileServiceFolder(target, serviceFolder, macroFolders_1, programFolders_2, compileTree)]; case 1: _a.sent(); return [2 /*return*/]; } }); }); })]; case 11: _a.sent(); return [4 /*yield*/, (0, utils_1.asyncForEach)(jobFolders, function (jobFolder) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, compileJobFolder(target, jobFolder, macroFolders_1, programFolders_2, compileTree)]; case 1: _a.sent(); return [2 /*return*/]; } }); }); })]; case 12: _a.sent(); return [3 /*break*/, 14]; case 13: error_3 = _a.sent(); throw error_3; case 14: return [2 /*return*/]; } }); }); } exports.compileJobsServicesTests = compileJobsServicesTests; function recreateBuildFolder() { var _a; return __awaiter(this, void 0, void 0, function () { var buildDestinationFolder, pathExists; return __generator(this, function (_b) { switch (_b.label) { case 0: buildDestinationFolder = process.sasjsConstants.buildDestinationFolder; (_a = process.logger) === null || _a === void 0 ? void 0 : _a.info('Recreating build folder...'); return [4 /*yield*/, (0, utils_1.fileExists)(buildDestinationFolder)]; case 1: pathExists = _b.sent(); if (!pathExists) return [3 /*break*/, 3]; return [4 /*yield*/, (0, utils_1.deleteFolder)(buildDestinationFolder)]; case 2: _b.sent(); _b.label = 3; case 3: return [4 /*yield*/, (0, utils_1.createFolder)(buildDestinationFolder)]; case 4: _b.sent(); return [2 /*return*/]; } }); }); } // REFACTOR: combine compileServiceFolder and compileJobFolder var compileServiceFolder = function (target, serviceFolder, macroFolders, programFolders, compileTree) { return __awaiter(void 0, void 0, void 0, function () { var destinationPath, subFolders, sourceFiles; return __generator(this, function (_a) { switch (_a.label) { case 0: destinationPath = (0, internal_1.getDestinationServicePath)(serviceFolder); return [4 /*yield*/, (0, utils_1.listSubFoldersInFolder)(destinationPath)]; case 1: subFolders = _a.sent(); return [4 /*yield*/, (0, utils_1.listFilesInFolder)(serviceFolder) // Checks if file in sasjsbuild folder exists in source folder. // If not, it means that the file shouldn't be compiled. ]; case 2: sourceFiles = _a.sent(); // Checks if file in sasjsbuild folder exists in source folder. // If not, it means that the file shouldn't be compiled. return [4 /*yield*/, (0, utils_1.asyncForEach)(sourceFiles, function (fileName, i) { return __awaiter(void 0, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, (0, utils_1.fileExists)(path_1.default.join(serviceFolder, fileName))]; case 1: if (!(_a.sent())) { sourceFiles.splice(i, 1); } return [2 /*return*/]; } }); }); })]; case 3: // Checks if file in sasjsbuild folder exists in source folder. // If not, it means that the file shouldn't be compiled. _a.sent(); return [4 /*yield*/, (0, utils_1.asyncForEach)(sourceFiles, function (fileName) { return __awaiter(void 0, void 0, void 0, function () { var filePath; return __generator(this, function (_a) { switch (_a.label) { case 0: filePath = path_1.default.join(destinationPath, fileName); if (!(0, utils_1.isTestFile)(filePath)) return [3 /*break*/, 2]; return [4 /*yield*/, (0, internal_1.compileTestFile)(target, filePath, '', false, undefined, compileTree)]; case 1: _a.sent(); return [3 /*break*/, 4]; case 2: return [4 /*yield*/, (0, internal_1.compileFile)(target, filePath, macroFolders, programFolders, undefined, compileTree, types_1.SASJsFileType.service, serviceFolder)]; case 3: _a.sent(); _a.label = 4; case 4: return [2 /*return*/]; } }); }); })]; case 4: _a.sent(); return [4 /*yield*/, (0, utils_1.asyncForEach)(subFolders, function (subFolder) { return __awaiter(void 0, void 0, void 0, function () { var sourceFolder, sourceFiles; return __generator(this, function (_a) { switch (_a.label) { case 0: sourceFolder = path_1.default.join(serviceFolder, subFolder); return [4 /*yield*/, (0, utils_1.listFilesInFolder)(sourceFolder)]; case 1: sourceFiles = _a.sent(); return [4 /*yield*/, (0, utils_1.asyncForEach)(sourceFiles, function (fileName) { return __awaiter(void 0, void 0, void 0, function () { var filePath; return __generator(this, function (_a) { switch (_a.label) { case 0: filePath = path_1.default.join(destinationPath, subFolder, fileName); if (!(0, utils_1.isTestFile)(filePath)) return [3 /*break*/, 2]; return [4 /*yield*/, (0, internal_1.compileTestFile)(target, filePath, '', false, undefined, compileTree)]; case 1: _a.sent(); return [3 /*break*/, 4]; case 2: return [4 /*yield*/, (0, internal_1.compileFile)(target, filePath, macroFolders, programFolders, undefined, compileTree, types_1.SASJsFileType.service, sourceFolder)]; case 3: _a.sent(); _a.label = 4; case 4: return [2 /*return*/]; } }); }); })]; case 2: _a.sent(); return [2 /*return*/]; } }); }); })]; case 5: _a.sent(); compileTree.saveTree(); return [2 /*return*/]; } }); }); }; var compileJobFolder = function (target, jobFolder, macroFolders, programFolders, compileTree) { return __awaiter(void 0, void 0, void 0, function () { var destinationPath, subFolders, sourceFiles; return __generator(this, function (_a) { switch (_a.label) { case 0: destinationPath = (0, internal_1.getDestinationJobPath)(jobFolder); return [4 /*yield*/, (0, utils_1.listSubFoldersInFolder)(destinationPath)]; case 1: subFolders = _a.sent(); return [4 /*yield*/, (0, utils_1.listFilesInFolder)(destinationPath) // Checks if file in sasjsbuild folder exists in source folder. // If not, it means that the file shouldn't be compiled. ]; case 2: sourceFiles = _a.sent(); // Checks if file in sasjsbuild folder exists in source folder. // If not, it means that the file shouldn't be compiled. return [4 /*yield*/, (0, utils_1.asyncForEach)(sourceFiles, function (fileName, i) { return __awaiter(void 0, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, (0, utils_1.fileExists)(path_1.default.join(jobFolder, fileName))]; case 1: if (!(_a.sent())) { sourceFiles.splice(i, 1); } return [2 /*return*/]; } }); }); })]; case 3: // Checks if file in sasjsbuild folder exists in source folder. // If not, it means that the file shouldn't be compiled. _a.sent(); return [4 /*yield*/, (0, utils_1.asyncForEach)(sourceFiles, function (fileName) { return __awaiter(void 0, void 0, void 0, function () { var filePath; return __generator(this, function (_a) { switch (_a.label) { case 0: filePath = path_1.default.join(destinationPath, fileName); if (!(0, utils_1.isTestFile)(fileName)) return [3 /*break*/, 2]; return [4 /*yield*/, (0, internal_1.compileTestFile)(target, filePath, '', false, undefined, compileTree)]; case 1: _a.sent(); return [3 /*break*/, 4]; case 2: return [4 /*yield*/, (0, internal_1.compileFile)(target, filePath, macroFolders, programFolders, undefined, compileTree, types_1.SASJsFileType.job, jobFolder)]; case 3: _a.sent(); _a.label = 4; case 4: return [2 /*return*/]; } }); }); })]; case 4: _a.sent(); return [4 /*yield*/, (0, utils_1.asyncForEach)(subFolders, function (subFolder) { return __awaiter(void 0, void 0, void 0, function () { var sourcePath, sourceFiles; return __generator(this, function (_a) { switch (_a.label) { case 0: sourcePath = path_1.default.join(jobFolder, subFolder); return [4 /*yield*/, (0, utils_1.listFilesInFolder)(sourcePath)]; case 1: sourceFiles = _a.sent(); return [4 /*yield*/, (0, utils_1.asyncForEach)(sourceFiles, function (fileName) { return __awaiter(void 0, void 0, void 0, function () { var filePath; return __generator(this, function (_a) { switch (_a.label) { case 0: filePath = path_1.default.join(destinationPath, subFolder, fileName); if (!(0, utils_1.isTestFile)(filePath)) return [3 /*break*/, 2]; return [4 /*yield*/, (0, internal_1.compileTestFile)(target, filePath, '', false, undefined, compileTree)]; case 1: _a.sent(); return [3 /*break*/, 4]; case 2: return [4 /*yield*/, (0, internal_1.compileFile)(target, filePath, macroFolders, programFolders, undefined, compileTree, types_1.SASJsFileType.job, sourcePath)]; case 3: _a.sent(); _a.label = 4; case 4: return [2 /*return*/]; } }); }); })]; case 2: _a.sent(); return [2 /*return*/]; } }); }); })]; case 5: _a.sent(); return [2 /*return*/]; } }); }); }; function compileWeb(target) { var _a, _b; return __awaiter(this, void 0, void 0, function () { var configuration, streamConfig, streamWeb; return __generator(this, function (_c) { switch (_c.label) { case 0: configuration = process.sasjsConfig; streamConfig = __assign(__assign({}, configuration === null || configuration === void 0 ? void 0 : configuration.streamConfig), target.streamConfig); streamWeb = (_a = streamConfig.streamWeb) !== null && _a !== void 0 ? _a : false; if (!streamWeb) return [3 /*break*/, 2]; (_b = process.logger) === null || _b === void 0 ? void 0 : _b.info('Compiling web app services since `streamWeb` is enabled.'); return [4 /*yield*/, (0, web_1.createWebAppServices)(target) .then(function () { var _a; return (_a = process.logger) === null || _a === void 0 ? void 0 : _a.success("Web app services have been compiled."); }) .catch(function (err) { var _a; (_a = process.logger) === null || _a === void 0 ? void 0 : _a.error('An error has occurred when compiling web app services.', err.toString()); })]; case 1: _c.sent(); _c.label = 2; case 2: return [2 /*return*/]; } }); }); } var syncFolder = function (target) { return __awaiter(void 0, void 0, void 0, function () { var configuration; return __generator(this, function (_a) { switch (_a.label) { case 0: configuration = process.sasjsConfig; if (!configuration.syncFolder) return [3 /*break*/, 2]; return [4 /*yield*/, (0, internal_1.copySyncFolder)(configuration.syncFolder)]; case 1: _a.sent(); _a.label = 2; case 2: if (!target.syncFolder) return [3 /*break*/, 4]; return [4 /*yield*/, (0, internal_1.copySyncFolder)(target.syncFolder)]; case 3: _a.sent(); _a.label = 4; case 4: return [2 /*return*/]; } }); }); };