UNPKG

@apigeeks/fbl-k8s-plugin

Version:

fbl wrapper plugin for helm and kubectl cli utilities

275 lines 13.1 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; 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 assert = require("assert"); const chai = require("chai"); const chaiAsPromised = require("chai-as-promised"); const typedi_1 = require("typedi"); const util_1 = require("util"); const fs_1 = require("fs"); const path_1 = require("path"); const mocha_typescript_1 = require("mocha-typescript"); const fbl_1 = require("fbl"); const kubectl_1 = require("../../../src/handlers/kubectl"); const services_1 = require("../../../src/services"); const K8sBaseHandlerTestSuite_1 = require("../K8sBaseHandlerTestSuite"); chai.use(chaiAsPromised); let K8sApplyGenericSecretActionHandlerTestSuite = class K8sApplyGenericSecretActionHandlerTestSuite extends K8sBaseHandlerTestSuite_1.K8sBaseHandlerTestSuite { failValidation() { return __awaiter(this, void 0, void 0, function* () { const actionHandler = new kubectl_1.K8sApplyGenericSecretActionHandler(); const context = fbl_1.ContextUtil.generateEmptyContext(); const snapshot = new fbl_1.ActionSnapshot('.', {}, '', 0, {}); yield chai.expect(actionHandler.validate([], context, snapshot, {})).to.be.rejected; yield chai.expect(actionHandler.validate({ name: 'test', }, context, snapshot, {})).to.be.rejected; yield chai.expect(actionHandler.validate({ name: 'test', files: [], }, context, snapshot, {})).to.be.rejected; yield chai.expect(actionHandler.validate({ name: 'test', inline: [], }, context, snapshot, {})).to.be.rejected; yield chai.expect(actionHandler.validate({ name: 'test', inline: {}, }, context, snapshot, {})).to.be.rejected; }); } passValidation() { return __awaiter(this, void 0, void 0, function* () { const actionHandler = new kubectl_1.K8sApplyGenericSecretActionHandler(); const context = fbl_1.ContextUtil.generateEmptyContext(); const snapshot = new fbl_1.ActionSnapshot('.', {}, '', 0, {}); yield actionHandler.validate({ name: 'test', files: ['test.yml'], }, context, snapshot, {}); yield actionHandler.validate({ name: 'test', inline: { test: 1, }, }, context, snapshot, {}); yield actionHandler.validate({ name: 'test', files: ['test.yml'], inline: { test: 1, }, }, context, snapshot, {}); }); } createNewSecretInline() { return __awaiter(this, void 0, void 0, function* () { const actionHandler = new kubectl_1.K8sApplyGenericSecretActionHandler(); const context = fbl_1.ContextUtil.generateEmptyContext(); const snapshot = new fbl_1.ActionSnapshot('.', {}, '', 0, {}); const options = { name: 'secret-generic-test-inline', namespace: 'default', inline: { host: 'foo.bar', port: 8000, }, }; yield actionHandler.validate(options, context, snapshot, {}); yield actionHandler.execute(options, context, snapshot, {}); const result = yield typedi_1.Container.get(services_1.K8sKubectlService).execKubectlCommand([ 'get', 'secret', options.name, '-o', 'json', ]); if (result.code !== 0) { throw new Error(`code: ${result.code};\nstdout: ${result.stdout};\nstderr: ${result.stderr}`); } const secret = JSON.parse(result.stdout); assert.deepStrictEqual(secret.data, { host: new Buffer('foo.bar').toString('base64'), port: new Buffer('8000').toString('base64'), }); assert.strictEqual(context.entities.registered.length, 1); assert.strictEqual(context.entities.created.length, 1); }); } createNewSecretFiles() { return __awaiter(this, void 0, void 0, function* () { const actionHandler = new kubectl_1.K8sApplyGenericSecretActionHandler(); const context = fbl_1.ContextUtil.generateEmptyContext(); const snapshot = new fbl_1.ActionSnapshot('.', {}, '', 0, {}); const tempFile = yield typedi_1.Container.get(fbl_1.TempPathsRegistry).createTempFile(false, '.txt'); yield util_1.promisify(fs_1.writeFile)(tempFile, 'test=true', 'utf8'); const options = { name: 'secret-generic-test-files', files: [tempFile], }; yield actionHandler.validate(options, context, snapshot, {}); yield actionHandler.execute(options, context, snapshot, {}); const result = yield typedi_1.Container.get(services_1.K8sKubectlService).execKubectlCommand([ 'get', 'secret', options.name, '-o', 'json', ]); if (result.code !== 0) { throw new Error(`code: ${result.code};\nstdout: ${result.stdout};\nstderr: ${result.stderr}`); } const secret = JSON.parse(result.stdout); assert.deepStrictEqual(secret.data, { [path_1.basename(tempFile)]: new Buffer('test=true').toString('base64'), }); assert.strictEqual(context.entities.registered.length, 1); assert.strictEqual(context.entities.created.length, 1); }); } createCombinedSecret() { return __awaiter(this, void 0, void 0, function* () { const actionHandler = new kubectl_1.K8sApplyGenericSecretActionHandler(); const context = fbl_1.ContextUtil.generateEmptyContext(); const snapshot = new fbl_1.ActionSnapshot('.', {}, '', 0, {}); const tempFile = yield typedi_1.Container.get(fbl_1.TempPathsRegistry).createTempFile(false, '.txt'); yield util_1.promisify(fs_1.writeFile)(tempFile, 'test=true', 'utf8'); const options = { name: 'secret-generic-test-combined', files: [tempFile], inline: { host: 'foo.bar', port: 8000, }, }; yield actionHandler.validate(options, context, snapshot, {}); yield actionHandler.execute(options, context, snapshot, {}); const result = yield typedi_1.Container.get(services_1.K8sKubectlService).execKubectlCommand([ 'get', 'secret', options.name, '-o', 'json', ]); if (result.code !== 0) { throw new Error(`code: ${result.code};\nstdout: ${result.stdout};\nstderr: ${result.stderr}`); } const secret = JSON.parse(result.stdout); assert.deepStrictEqual(secret.data, { [path_1.basename(tempFile)]: new Buffer('test=true').toString('base64'), host: new Buffer('foo.bar').toString('base64'), port: new Buffer('8000').toString('base64'), }); assert.strictEqual(context.entities.registered.length, 1); assert.strictEqual(context.entities.created.length, 1); }); } updateSecretByName() { return __awaiter(this, void 0, void 0, function* () { const actionHandler = new kubectl_1.K8sApplyGenericSecretActionHandler(); const context = fbl_1.ContextUtil.generateEmptyContext(); const snapshot = new fbl_1.ActionSnapshot('.', {}, '', 0, {}); const options = { name: 'secret-generic-test-override', inline: { host: 'foo.bar', port: 8000, }, }; yield actionHandler.validate(options, context, snapshot, {}); yield actionHandler.execute(options, context, snapshot, {}); let result = yield typedi_1.Container.get(services_1.K8sKubectlService).execKubectlCommand([ 'get', 'secret', options.name, '-o', 'json', ]); if (result.code !== 0) { throw new Error(`code: ${result.code};\nstdout: ${result.stdout};\nstderr: ${result.stderr}`); } let secret = JSON.parse(result.stdout); assert.deepStrictEqual(secret.data, { host: new Buffer('foo.bar').toString('base64'), port: new Buffer('8000').toString('base64'), }); // update secret options.inline.port = 9999; yield actionHandler.execute(options, context, snapshot, {}); result = yield typedi_1.Container.get(services_1.K8sKubectlService).execKubectlCommand([ 'get', 'secret', options.name, '-o', 'json', ]); if (result.code !== 0) { throw new Error(`code: ${result.code};\nstdout: ${result.stdout};\nstderr: ${result.stderr}`); } secret = JSON.parse(result.stdout); assert.deepStrictEqual(secret.data, { host: new Buffer('foo.bar').toString('base64'), port: new Buffer('9999').toString('base64'), }); assert.strictEqual(context.entities.registered.length, 2); assert.strictEqual(context.entities.created.length, 1); assert.strictEqual(context.entities.updated.length, 1); }); } }; __decorate([ mocha_typescript_1.test(), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", Promise) ], K8sApplyGenericSecretActionHandlerTestSuite.prototype, "failValidation", null); __decorate([ mocha_typescript_1.test(), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", Promise) ], K8sApplyGenericSecretActionHandlerTestSuite.prototype, "passValidation", null); __decorate([ mocha_typescript_1.test(), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", Promise) ], K8sApplyGenericSecretActionHandlerTestSuite.prototype, "createNewSecretInline", null); __decorate([ mocha_typescript_1.test(), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", Promise) ], K8sApplyGenericSecretActionHandlerTestSuite.prototype, "createNewSecretFiles", null); __decorate([ mocha_typescript_1.test(), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", Promise) ], K8sApplyGenericSecretActionHandlerTestSuite.prototype, "createCombinedSecret", null); __decorate([ mocha_typescript_1.test(), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", Promise) ], K8sApplyGenericSecretActionHandlerTestSuite.prototype, "updateSecretByName", null); K8sApplyGenericSecretActionHandlerTestSuite = __decorate([ mocha_typescript_1.suite() ], K8sApplyGenericSecretActionHandlerTestSuite); //# sourceMappingURL=K8sApplyGenericSecretActionHandlerTestSuite.js.map