mirror of
https://github.com/balena-os/balena-supervisor.git
synced 2025-01-03 04:26:44 +00:00
382cdb0cfa
This replaces all relative paths in the test suite (e.g `../src/compose/service.ts`) with the aliased path configured through tsconfig. This is a big change but it doesn't affect any functionality
79 lines
2.5 KiB
TypeScript
79 lines
2.5 KiB
TypeScript
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';
|
|
|
|
import Service from '~/src/compose/service';
|
|
import Network from '~/src/compose/network';
|
|
import Volume from '~/src/compose/volume';
|
|
|
|
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 () => {
|
|
// 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;
|
|
});
|
|
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(
|
|
_downloading: number[],
|
|
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();
|
|
}
|