UNPKG

@sasjs/cli

Version:

Command line interface for SASjs

428 lines (427 loc) 28.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 }); var path_1 = __importDefault(require("path")); var utils_1 = require("@sasjs/utils"); var internalModule = __importStar(require("@sasjs/utils/sasjsCli/getInitTerm")); var getInitTerm_1 = require("@sasjs/utils/sasjsCli/getInitTerm"); var test_1 = require("../../../utils/test"); var utils_2 = require("../../../utils"); var internal_1 = require("../internal"); var loadDependencies_1 = require("../internal/loadDependencies"); var fakeInit = "/**\n @file serviceinit.sas\n @brief this file is called with every service\n @details This file is included in *every* service, *after* the macros and *before* the service code.\n\n ".concat(utils_1.DependencyHeader.Macro, "\n @li mf_abort.sas\n\n**/\n\noptions\n DATASTMTCHK=ALLKEYWORDS /* some sites have this enabled */\n PS=MAX /* reduce log size slightly */\n;\n%put service is starting!!;"); var fakeTerm = "/**\n @file serviceterm.sas\n @brief this file is called at the end of every service\n @details This file is included at the *end* of every service.\n\n ".concat(utils_1.DependencyHeader.Macro, "\n @li mf_abort.sas\n @li mf_existds.sas\n\n**/\n\n%put service is finishing. Thanks, SASjs!;"); var fakeInit2 = "/**\n @file serviceinit.sas\n @brief this file is called with every service\n @details This file is included in *every* service, *after* the macros and *before* the service code.\n\n ".concat(utils_1.DependencyHeader.Macro, "\n @li mf_abort.sas\n\n**/\n\noptions\n DATASTMTCHK=ALLKEYWORDS /* some sites have this enabled */\n PS=MAX /* reduce log size slightly */\n;\n%put service is starting!!;"); var fakeTerm2 = "/**\n @file serviceterm.sas\n @brief this file is called at the end of every service\n @details This file is included at the *end* of every service.\n\n ".concat(utils_1.DependencyHeader.Macro, "\n @li mf_abort.sas\n @li mf_existds.sas\n\n**/\n\n%put service is finishing. Thanks, SASjs!;"); var fakeJobInit = "/**\n @file\n @brief This code is inserted into the beginning of each Viya Job.\n @details Inserted during the `sasjs compile` step. Add any code here that\n should go at the beginning of every deployed job.\n\n The path to this file should be listed in the `jobInit` property of the\n sasjsconfig file.\n\n ".concat(utils_1.DependencyHeader.DeprecatedInclude, "\n @li test.sas TEST\n\n ").concat(utils_1.DependencyHeader.Macro, "\n @li examplemacro.sas\n\n**/\n\n%example(Job Init is executing!)\n\n%let mylib=WORK;"); var fakeJobInit2 = "/**\n @file\n @brief This code is inserted into the beginning of each Viya Job.\n @details Inserted during the `sasjs compile` step. Add any code here that\n should go at the beginning of every deployed job.\n\n The path to this file should be listed in the `jobInit` property of the\n sasjsconfig file.\n\n ".concat(utils_1.DependencyHeader.Include, "\n @li test.sas TEST\n\n ").concat(utils_1.DependencyHeader.Macro, "\n @li examplemacro.sas\n\n**/\n\n%example(Job Init is executing!)\n\n%let mylib=WORK;"); var fakeProgramLines = [ 'filename TEST temp;', 'data _null_;', 'file TEST lrecl=32767;', "put '%put ''Hello, world!'';';", 'run;' ]; var jobConfig = function (root) { if (root === void 0) { root = true; } return ({ initProgram: '', termProgram: '', jobFolders: [], macroVars: root ? { macrovar1: 'macro job value configuration 1', macrovar2: 'macro job value configuration 2' } : { macrovar2: 'macro job value target 2', macrovar3: 'macro job value target 3' } }); }; var serviceConfig = function (root) { if (root === void 0) { root = true; } return ({ initProgram: '', termProgram: '', serviceFolders: [], macroVars: root ? { macrovar1: 'macro service value configuration 1', macrovar2: 'macro service value configuration 2' } : { macrovar2: 'macro service value target 2', macrovar3: 'macro service value target 3' } }); }; var compiledVars = function (type) { return "* ".concat((0, utils_1.capitalizeFirstChar)(type), " Variables start;\n\n%let macrovar1=macro ").concat(type.toLowerCase(), " value configuration 1;\n%let macrovar2=macro ").concat(type.toLowerCase(), " value target 2;\n%let macrovar3=macro ").concat(type.toLowerCase(), " value target 3;\n\n* ").concat((0, utils_1.capitalizeFirstChar)(type), " Variables end;"); }; describe('loadDependencies', function () { var appName = "cli-tests-load-dependencies-".concat((0, utils_1.generateTimestamp)()); var temp = (0, test_1.generateTestTarget)(appName, '/Public/app', { serviceFolders: [path_1.default.join('sasjs', 'services')], initProgram: '', termProgram: '', macroVars: {} }, utils_1.ServerType.SasViya); var target = new utils_1.Target(__assign(__assign({}, temp.toJson()), { jobConfig: jobConfig(false), serviceConfig: serviceConfig(false) })); var compileTree; beforeAll(function () { return __awaiter(void 0, void 0, void 0, function () { var _a; return __generator(this, function (_b) { switch (_b.label) { case 0: return [4 /*yield*/, (0, utils_2.setConstants)(false)]; case 1: _b.sent(); compileTree = (0, loadDependencies_1.getCompileTree)(target); return [4 /*yield*/, (0, test_1.createTestMinimalApp)(__dirname, target.name)]; case 2: _b.sent(); return [4 /*yield*/, (0, test_1.updateConfig)({ jobConfig: jobConfig(), serviceConfig: serviceConfig() })]; case 3: _b.sent(); _a = process; return [4 /*yield*/, (0, utils_2.getLocalConfig)()]; case 4: _a.sasjsConfig = _b.sent(); return [2 /*return*/]; } }); }); }); afterAll(function () { return __awaiter(void 0, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, (0, test_1.removeTestApp)(__dirname, target.name)]; case 1: _a.sent(); return [2 /*return*/]; } }); }); }); test("it should load dependencies for a service with ".concat(utils_1.DependencyHeader.DeprecatedMacro), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeInit, fakeTerm); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [], [], utils_1.SASJsFileType.service, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Service)); expect(/\* ServiceInit start;/.test(dependencies)).toEqual(true); expect(/\* ServiceInit end;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm start;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm end;/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(/%macro mf_existds/.test(dependencies)).toEqual(true); return [2 /*return*/]; } }); }); }); test("it should load dependencies for a job ".concat(utils_1.DependencyHeader.Macro), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeInit, fakeTerm); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [], [], utils_1.SASJsFileType.job, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Job)); expect(/\* JobInit start;/.test(dependencies)).toEqual(true); expect(/\* JobInit end;/.test(dependencies)).toEqual(true); expect(/\* JobTerm start;/.test(dependencies)).toEqual(true); expect(/\* JobTerm end;/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(/%macro mf_existds/.test(dependencies)).toEqual(true); return [2 /*return*/]; } }); }); }); test("it should load dependencies for a service with ".concat(utils_1.DependencyHeader.Macro), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeInit2, fakeTerm2); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [], [], utils_1.SASJsFileType.service, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Service)); expect(/\* ServiceInit start;/.test(dependencies)).toEqual(true); expect(/\* ServiceInit end;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm start;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm end;/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(/%macro mf_existds/.test(dependencies)).toEqual(true); return [2 /*return*/]; } }); }); }); test("it should load dependencies for a job ".concat(utils_1.DependencyHeader.Macro), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeInit2, fakeTerm2); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [], [], utils_1.SASJsFileType.job, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Job)); expect(/\* JobInit start;/.test(dependencies)).toEqual(true); expect(/\* JobInit end;/.test(dependencies)).toEqual(true); expect(/\* JobTerm start;/.test(dependencies)).toEqual(true); expect(/\* JobTerm end;/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(/%macro mf_existds/.test(dependencies)).toEqual(true); return [2 /*return*/]; } }); }); }); test("it should load programs for a service with ".concat(utils_1.DependencyHeader.DeprecatedInclude), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeJobInit, fakeTerm); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [path_1.default.join(__dirname, './macros')], [path_1.default.join(__dirname, './'), path_1.default.join(__dirname, './services')], utils_1.SASJsFileType.service, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Service)); expect(/\* ServiceInit start;/.test(dependencies)).toEqual(true); expect(/\* ServiceInit end;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm start;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm end;/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(/%macro mf_existds/.test(dependencies)).toEqual(true); return [2 /*return*/]; } }); }); }); test("it should load programs for a job ".concat(utils_1.DependencyHeader.DeprecatedInclude), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeJobInit, fakeTerm); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [path_1.default.join(__dirname, './macros')], [path_1.default.join(__dirname, './'), path_1.default.join(__dirname, './services')], utils_1.SASJsFileType.job, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Job)); expect(/\* JobInit start;/.test(dependencies)).toEqual(true); expect(/\* JobInit end;/.test(dependencies)).toEqual(true); expect(/\* JobTerm start;/.test(dependencies)).toEqual(true); expect(/\* JobTerm end;/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(/%macro mf_existds/.test(dependencies)).toEqual(true); return [2 /*return*/]; } }); }); }); test("it should load programs for a service with ".concat(utils_1.DependencyHeader.Include), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeJobInit2, fakeTerm2); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [path_1.default.join(__dirname, './macros')], [path_1.default.join(__dirname, './'), path_1.default.join(__dirname, './services')], utils_1.SASJsFileType.service, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Service)); expect(/\* ServiceInit start;/.test(dependencies)).toEqual(true); expect(/\* ServiceInit end;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm start;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm end;/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(/%macro mf_existds/.test(dependencies)).toEqual(true); return [2 /*return*/]; } }); }); }); test("it should load programs for a job ".concat(utils_1.DependencyHeader.Include), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeJobInit2, fakeTerm2); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [path_1.default.join(__dirname, './macros')], [path_1.default.join(__dirname, './'), path_1.default.join(__dirname, './services')], utils_1.SASJsFileType.job, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Job)); expect(/\* JobInit start;/.test(dependencies)).toEqual(true); expect(/\* JobInit end;/.test(dependencies)).toEqual(true); expect(/\* JobTerm start;/.test(dependencies)).toEqual(true); expect(/\* JobTerm end;/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(/%macro mf_existds/.test(dependencies)).toEqual(true); return [2 /*return*/]; } }); }); }); test("it should load dependencies for a job having jobInit's ".concat(utils_1.DependencyHeader.DeprecatedInclude), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeJobInit, fakeTerm2); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [path_1.default.join(__dirname, './macros')], [path_1.default.join(__dirname, './'), path_1.default.join(__dirname, './services')], utils_1.SASJsFileType.job, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Job)); expect(/\* JobInit start;/.test(dependencies)).toEqual(true); expect(/\* JobInit end;/.test(dependencies)).toEqual(true); expect(/\* JobTerm start;/.test(dependencies)).toEqual(true); expect(/\* JobTerm end;/.test(dependencies)).toEqual(true); expect(/%macro examplemacro/.test(dependencies)).toEqual(true); expect(/%macro doesnothing/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(/%macro mf_existds/.test(dependencies)).toEqual(true); expect(dependencies).toEqual(expect.stringContaining(fakeProgramLines.join('\n'))); return [2 /*return*/]; } }); }); }); test("it should load dependencies for a job having jobTerm's ".concat(utils_1.DependencyHeader.DeprecatedInclude), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeInit2, fakeJobInit); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [path_1.default.join(__dirname, './macros')], [path_1.default.join(__dirname, './'), path_1.default.join(__dirname, './services')], utils_1.SASJsFileType.job, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Job)); expect(/\* JobInit start;/.test(dependencies)).toEqual(true); expect(/\* JobInit end;/.test(dependencies)).toEqual(true); expect(/\* JobTerm start;/.test(dependencies)).toEqual(true); expect(/\* JobTerm end;/.test(dependencies)).toEqual(true); expect(/%macro examplemacro/.test(dependencies)).toEqual(true); expect(/%macro doesnothing/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(dependencies).toEqual(expect.stringContaining(fakeProgramLines.join('\n'))); return [2 /*return*/]; } }); }); }); test("it should load dependencies for a service having serviceInit's ".concat(utils_1.DependencyHeader.DeprecatedInclude), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeJobInit, fakeTerm2); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [path_1.default.join(__dirname, './macros')], [path_1.default.join(__dirname, './'), path_1.default.join(__dirname, './services')], utils_1.SASJsFileType.service, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Service)); expect(/\* ServiceInit start;/.test(dependencies)).toEqual(true); expect(/\* ServiceInit end;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm start;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm end;/.test(dependencies)).toEqual(true); expect(/%macro examplemacro/.test(dependencies)).toEqual(true); expect(/%macro doesnothing/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(/%macro mf_existds/.test(dependencies)).toEqual(true); expect(dependencies).toEqual(expect.stringContaining(fakeProgramLines.join('\n'))); return [2 /*return*/]; } }); }); }); test("it should load dependencies for a service having serviceTerm's ".concat(utils_1.DependencyHeader.DeprecatedInclude), function () { return __awaiter(void 0, void 0, void 0, function () { var dependencies; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, getInitTerm_1.mockGetProgram)(internalModule, fakeInit2, fakeJobInit); return [4 /*yield*/, (0, loadDependencies_1.loadDependencies)(target, path_1.default.join(__dirname, './service.sas'), [path_1.default.join(__dirname, './macros')], [path_1.default.join(__dirname, './'), path_1.default.join(__dirname, './services')], utils_1.SASJsFileType.service, compileTree)]; case 1: dependencies = _a.sent(); expect(dependencies).toContain(compiledVars(internal_1.SasFileType.Service)); expect(/\* ServiceInit start;/.test(dependencies)).toEqual(true); expect(/\* ServiceInit end;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm start;/.test(dependencies)).toEqual(true); expect(/\* ServiceTerm end;/.test(dependencies)).toEqual(true); expect(/%macro examplemacro/.test(dependencies)).toEqual(true); expect(/%macro doesnothing/.test(dependencies)).toEqual(true); expect(/%macro mf_abort/.test(dependencies)).toEqual(true); expect(dependencies).toEqual(expect.stringContaining(fakeProgramLines.join('\n'))); return [2 /*return*/]; } }); }); }); });