mirror of
https://github.com/balena-os/balena-supervisor.git
synced 2025-01-25 13:49:33 +00:00
827f892c13
This means that configuration backend tests no longer use stubs and (mostly) avoid internal dependencies in the tests. Instead of stubs and mock-fs, the tests use [testfs](https://github.com/balena-io-modules/mocha-pod#working-with-the-filesystem) which allows working with a real filesystem and ensuring everything is re-set between tests. This is the last change needed in order to be able to merge #1971. Here is the list of changes - [x] Migrate splash image backend tests - [x] Migrate extlinux backend tests - [x] Migrate config.txt backend tests - [x] Migrate extra-uenv config tests - [x] Migrate odmdata config tests - [x] Migrate config utils tests - [x] Migrate device-config tests Change-type: patch
120 lines
3.3 KiB
TypeScript
120 lines
3.3 KiB
TypeScript
import { expect } from 'chai';
|
|
import { testfs } from 'mocha-pod';
|
|
|
|
import * as configUtils from '~/src/config/utils';
|
|
import { ExtraUEnv } from '~/src/config/backends/extra-uEnv';
|
|
import { Extlinux } from '~/src/config/backends/extlinux';
|
|
import { ConfigTxt } from '~/src/config/backends/config-txt';
|
|
import { ConfigFs } from '~/src/config/backends/config-fs';
|
|
import { SplashImage } from '~/src/config/backends/splash-image';
|
|
import { ConfigBackend } from '~/src/config/backends/backend';
|
|
|
|
import * as hostUtils from '~/lib/host-utils';
|
|
|
|
const keys = <T extends object>(obj: T) => Object.keys(obj) as Array<keyof T>;
|
|
|
|
describe('config/utils', () => {
|
|
it('gets list of supported backends', async () => {
|
|
const tFs = await testfs({
|
|
// This is only needed so config.get doesn't fail
|
|
[hostUtils.pathOnBoot('config.json')]: JSON.stringify({
|
|
deviceType: 'raspberrypi4',
|
|
}),
|
|
}).enable();
|
|
|
|
// Get list of backends
|
|
const devices = await configUtils.getSupportedBackends();
|
|
expect(devices.length).to.equal(2);
|
|
expect(devices[0].constructor.name).to.equal('ConfigTxt');
|
|
expect(devices[1].constructor.name).to.equal('SplashImage');
|
|
|
|
await tFs.restore();
|
|
// TO-DO: When we have a device that will match for multiple backends
|
|
// add a test that we get more then 1 backend for that device
|
|
});
|
|
|
|
it('transforms environment variables to boot configs', () => {
|
|
keys(CONFIGS).forEach((key) => {
|
|
expect(
|
|
configUtils.envToBootConfig(BACKENDS[key], CONFIGS[key].envVars),
|
|
).to.deep.equal(CONFIGS[key].bootConfig);
|
|
});
|
|
});
|
|
|
|
it('transforms boot configs to environment variables', () => {
|
|
keys(CONFIGS).forEach((key) => {
|
|
expect(
|
|
configUtils.bootConfigToEnv(BACKENDS[key], CONFIGS[key].bootConfig),
|
|
).to.deep.equal(CONFIGS[key].envVars);
|
|
});
|
|
});
|
|
});
|
|
|
|
const BACKENDS: Record<string, ConfigBackend> = {
|
|
extraUEnv: new ExtraUEnv(),
|
|
extlinux: new Extlinux(),
|
|
configtxt: new ConfigTxt(),
|
|
configfs: new ConfigFs(),
|
|
splashImage: new SplashImage(),
|
|
};
|
|
|
|
const CONFIGS = {
|
|
extraUEnv: {
|
|
envVars: {
|
|
HOST_EXTLINUX_fdt: '/boot/mycustomdtb.dtb',
|
|
HOST_EXTLINUX_isolcpus: '1,2,3',
|
|
HOST_EXTLINUX_rootwait: '',
|
|
},
|
|
bootConfig: {
|
|
fdt: '/boot/mycustomdtb.dtb',
|
|
isolcpus: '1,2,3',
|
|
rootwait: '',
|
|
},
|
|
},
|
|
extlinux: {
|
|
envVars: {
|
|
HOST_EXTLINUX_fdt: '/boot/mycustomdtb.dtb',
|
|
HOST_EXTLINUX_isolcpus: '1,2,3',
|
|
HOST_EXTLINUX_rootwait: '',
|
|
},
|
|
bootConfig: {
|
|
fdt: '/boot/mycustomdtb.dtb',
|
|
isolcpus: '1,2,3',
|
|
rootwait: '',
|
|
},
|
|
},
|
|
configtxt: {
|
|
envVars: {
|
|
HOST_CONFIG_initramfs: 'initramf.gz 0x00800000',
|
|
HOST_CONFIG_dtparam: '"i2c=on","audio=on"',
|
|
HOST_CONFIG_dtoverlay:
|
|
'"ads7846","lirc-rpi,gpio_out_pin=17,gpio_in_pin=13"',
|
|
HOST_CONFIG_foobar: 'baz',
|
|
},
|
|
bootConfig: {
|
|
initramfs: 'initramf.gz 0x00800000',
|
|
dtparam: ['i2c=on', 'audio=on'],
|
|
dtoverlay: ['ads7846', 'lirc-rpi,gpio_out_pin=17,gpio_in_pin=13'],
|
|
foobar: 'baz',
|
|
},
|
|
},
|
|
splashImage: {
|
|
envVars: {
|
|
HOST_SPLASH_image: '',
|
|
},
|
|
bootConfig: {
|
|
image: '',
|
|
},
|
|
},
|
|
// TO-DO: Config-FS is commented out because it behaves differently and doesn't
|
|
// add value to the Config Utilities if we make it work but would like to add it
|
|
// configfs: {
|
|
// envVars: {
|
|
// ssdt: 'spidev1,1'
|
|
// },
|
|
// bootConfig: {
|
|
// ssdt: ['spidev1,1']
|
|
// },
|
|
// },
|
|
};
|