UNPKG

@kui-shell/plugin-kubectl

Version:

Kubernetes visualization plugin for kubernetes

68 lines 3.49 kB
/* * Copyright 2020 The Kubernetes Authors * * 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) { 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()); }); }; import { Common, CLI, ReplExpect, Selectors } from '@kui-shell/test'; import { waitTillNone, waitForGreen, createNS, allocateNS, deleteNS } from '@kui-shell/plugin-kubectl/tests/lib/k8s/utils'; const kubectl = 'kubectl'; const name = 'foo-secret'; const pipeSecret = 'pipe-secret'; describe('kubectl secrets', function () { before(Common.before(this)); after(Common.after(this)); const ns = createNS(); const inNamespace = `-n ${ns}`; allocateNS(this, ns); // test for create --dry-run -o yaml | kubectl apply -f, i.e. the pipe part it('should create pipe to kubectl apply -f', () => __awaiter(this, void 0, void 0, function* () { return CLI.command(`kubectl create secret generic ${pipeSecret} ${inNamespace} -o yaml --dry-run=client --save-config --from-literal=foo=bar | kubectl apply -f - ${inNamespace}`, this.app) .then(ReplExpect.okWithString(`${pipeSecret} created`)) .catch(Common.oops(this, true)); })); it('should list the pipe secret', () => __awaiter(this, void 0, void 0, function* () { return CLI.command(`kubectl get secret ${pipeSecret} ${inNamespace}`, this.app) .then(ReplExpect.okWith(pipeSecret)) .catch(Common.oops(this, true)); })); it('should create a generic secret', () => __awaiter(this, void 0, void 0, function* () { try { const selector = yield CLI.command(`${kubectl} create secret generic ${name} ${inNamespace}`, this.app).then(ReplExpect.okWithCustom({ selector: Selectors.BY_NAME(name) })); // wait for the badge to become green yield waitForGreen(this.app, selector); } catch (err) { yield Common.oops(this, true)(err); } })); it('should delete a generic secret', () => __awaiter(this, void 0, void 0, function* () { try { yield CLI.command(`${kubectl} delete secret ${name} ${inNamespace}`, this.app); yield waitTillNone('secret', undefined, name, undefined, inNamespace)(this.app); } catch (err) { yield Common.oops(this, true)(err); } })); deleteNS(this, ns); }); //# sourceMappingURL=secrets.js.map