@apigeeks/fbl-k8s-plugin
Version:
fbl wrapper plugin for helm and kubectl cli utilities
275 lines • 13.1 kB
JavaScript
;
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