2022-08-17 23:35:08 +00:00
|
|
|
import * as networkManager from '~/src/compose/network-manager';
|
|
|
|
import * as volumeManager from '~/src/compose/volume-manager';
|
|
|
|
import * as serviceManager from '~/src/compose/service-manager';
|
|
|
|
import * as imageManager from '~/src/compose/images';
|
2020-08-13 12:25:39 +00:00
|
|
|
|
2022-08-17 23:35:08 +00:00
|
|
|
import Service from '~/src/compose/service';
|
|
|
|
import Network from '~/src/compose/network';
|
|
|
|
import Volume from '~/src/compose/volume';
|
2020-08-13 12:25:39 +00:00
|
|
|
|
|
|
|
const originalVolGetAll = volumeManager.getAll;
|
|
|
|
const originalSvcGetAll = serviceManager.getAll;
|
|
|
|
const originalNetGetAll = networkManager.getAll;
|
|
|
|
const originalNeedsClean = imageManager.isCleanupNeeded;
|
|
|
|
const originalImageAvailable = imageManager.getAvailable;
|
|
|
|
const originalNetworkReady = networkManager.supervisorNetworkReady;
|
|
|
|
|
|
|
|
export function mockManagers(svcs: Service[], vols: Volume[], nets: Network[]) {
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
volumeManager.getAll = async () => vols;
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
networkManager.getAll = async () => nets;
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
serviceManager.getAll = async () => {
|
2020-11-19 01:37:34 +00:00
|
|
|
// Filter services that are being removed
|
|
|
|
svcs = svcs.filter((s) => s.status !== 'removing');
|
|
|
|
// Update Installing containers to Running
|
|
|
|
svcs = svcs.map((s) => {
|
|
|
|
if (s.status === 'Installing') {
|
|
|
|
s.status = 'Running';
|
|
|
|
}
|
|
|
|
return s;
|
|
|
|
});
|
2020-08-13 12:25:39 +00:00
|
|
|
return svcs;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
function unmockManagers() {
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
volumeManager.getAll = originalVolGetAll;
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
networkManager.getAll = originalNetGetAll;
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
serviceManager.getall = originalSvcGetAll;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function mockImages(
|
2021-09-10 20:35:56 +00:00
|
|
|
_downloading: number[],
|
2020-08-13 12:25:39 +00:00
|
|
|
cleanup: boolean,
|
|
|
|
available: imageManager.Image[],
|
|
|
|
) {
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
imageManager.isCleanupNeeded = async () => cleanup;
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
imageManager.getAvailable = async () => available;
|
|
|
|
}
|
|
|
|
|
|
|
|
function unmockImages() {
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
imageManager.isCleanupNeeded = originalNeedsClean;
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
imageManager.getAvailable = originalImageAvailable;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function mockSupervisorNetwork(exists: boolean) {
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
networkManager.supervisorNetworkReady = async () => exists;
|
|
|
|
}
|
|
|
|
|
|
|
|
function unmockSupervisorNetwork() {
|
|
|
|
// @ts-expect-error Assigning to a RO property
|
|
|
|
networkManager.supervisorNetworkReady = originalNetworkReady;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function unmockAll() {
|
|
|
|
unmockManagers();
|
|
|
|
unmockImages();
|
|
|
|
unmockSupervisorNetwork();
|
|
|
|
}
|