1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00

Set defaults for EndpointSubsets (#3454)

This commit is contained in:
Sebastian Malton 2021-07-27 08:54:14 -04:00 committed by GitHub
parent 270d9d631c
commit f507ec9e6c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 77 additions and 20 deletions

View File

@ -0,0 +1,60 @@
/**
* Copyright (c) 2021 OpenLens Authors
*
* Permission is hereby granted, free of charge, to any person obtaining a copy of
* this software and associated documentation files (the "Software"), to deal in
* the Software without restriction, including without limitation the rights to
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
* the Software, and to permit persons to whom the Software is furnished to do so,
* subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
import { EndpointSubset } from "../endpoints";
describe("endpoint tests", () => {
describe("EndpointSubset", () => {
it.each([
4,
false,
null,
{},
[],
"ahe",
/a/,
])("should always initialize fields when given %j", (data: any) => {
const sub = new EndpointSubset(data);
expect(sub.addresses).toStrictEqual([]);
expect(sub.notReadyAddresses).toStrictEqual([]);
expect(sub.ports).toStrictEqual([]);
});
it("toString should be addresses X ports", () => {
const sub = new EndpointSubset({
addresses: [{
ip: "1.1.1.1",
}, {
ip: "1.1.1.2",
}] as any,
notReadyAddresses: [],
ports: [{
port: "81",
}, {
port: "82",
}] as any,
});
expect(sub.toString()).toBe("1.1.1.1:81, 1.1.1.1:82, 1.1.1.2:81, 1.1.1.2:82");
});
});
});

View File

@ -23,6 +23,7 @@ import { autoBind } from "../../utils";
import { KubeObject } from "../kube-object"; import { KubeObject } from "../kube-object";
import { KubeApi } from "../kube-api"; import { KubeApi } from "../kube-api";
import type { KubeJsonApiData } from "../kube-json-api"; import type { KubeJsonApiData } from "../kube-json-api";
import { get } from "lodash";
export interface IEndpointPort { export interface IEndpointPort {
name?: string; name?: string;
@ -63,6 +64,10 @@ export class EndpointAddress implements IEndpointAddress {
resourceVersion: string; resourceVersion: string;
}; };
static create(data: IEndpointAddress): EndpointAddress {
return new EndpointAddress(data);
}
constructor(data: IEndpointAddress) { constructor(data: IEndpointAddress) {
Object.assign(this, data); Object.assign(this, data);
} }
@ -90,35 +95,27 @@ export class EndpointSubset implements IEndpointSubset {
ports: IEndpointPort[]; ports: IEndpointPort[];
constructor(data: IEndpointSubset) { constructor(data: IEndpointSubset) {
Object.assign(this, data); this.addresses = get(data, "addresses", []);
this.notReadyAddresses = get(data, "notReadyAddresses", []);
this.ports = get(data, "ports", []);
} }
getAddresses(): EndpointAddress[] { getAddresses(): EndpointAddress[] {
const addresses = this.addresses || []; return this.addresses.map(EndpointAddress.create);
return addresses.map(a => new EndpointAddress(a));
} }
getNotReadyAddresses(): EndpointAddress[] { getNotReadyAddresses(): EndpointAddress[] {
const notReadyAddresses = this.notReadyAddresses || []; return this.notReadyAddresses.map(EndpointAddress.create);
return notReadyAddresses.map(a => new EndpointAddress(a));
} }
toString(): string { toString(): string {
if(!this.addresses) { return this.addresses
return ""; .map(address => (
} this.ports
.map(port => `${address.ip}:${port.port}`)
return this.addresses.map(address => { .join(", ")
if (!this.ports) { ))
return address.ip; .join(", ");
}
return this.ports.map(port => {
return `${address.ip}:${port.port}`;
}).join(", ");
}).join(", ");
} }
} }