2020-04-09 10:47:48 +00:00
|
|
|
import * as upath from 'upath';
|
2019-12-09 11:42:55 +00:00
|
|
|
import { platform as _platform } from '../lib/platform';
|
|
|
|
import { getConfig } from '../lib/config/defaults';
|
2019-12-17 05:56:42 +00:00
|
|
|
import { RenovateConfig as _RenovateConfig } from '../lib/config';
|
2019-12-09 11:42:55 +00:00
|
|
|
|
2019-12-04 03:29:27 +00:00
|
|
|
/**
|
|
|
|
* Simple wrapper for getting mocked version of a module
|
|
|
|
* @param module module which is mocked by `jest.mock`
|
|
|
|
*/
|
|
|
|
export function mocked<T>(module: T): jest.Mocked<T> {
|
|
|
|
return module as never;
|
|
|
|
}
|
2019-12-09 11:42:55 +00:00
|
|
|
|
2020-04-09 10:47:48 +00:00
|
|
|
/**
|
|
|
|
* Partially mock a module, providing an object with explicit mocks
|
|
|
|
* @param moduleName The module to mock
|
|
|
|
* @param overrides An object containing the mocks
|
|
|
|
* @example
|
|
|
|
* jest.mock('../../util/exec/docker/index', () =>
|
|
|
|
* require('../../../test/util').mockPartial('../../util/exec/docker/index', {
|
|
|
|
* removeDanglingContainers: jest.fn(),
|
|
|
|
* })
|
|
|
|
* );
|
|
|
|
*/
|
|
|
|
export function mockPartial(moduleName: string, overrides?: object): unknown {
|
|
|
|
const absolutePath = upath.join(module.parent.filename, '../', moduleName);
|
|
|
|
const originalModule = jest.requireActual(absolutePath);
|
|
|
|
return {
|
|
|
|
__esModule: true,
|
|
|
|
...originalModule,
|
|
|
|
...overrides,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2020-02-03 20:19:42 +00:00
|
|
|
/**
|
|
|
|
* Simply wrapper to create partial mocks.
|
|
|
|
* @param obj Object to cast to final type
|
|
|
|
*/
|
|
|
|
export function partial<T>(obj: Partial<T>): T {
|
|
|
|
return obj as T;
|
|
|
|
}
|
|
|
|
|
2019-12-09 11:42:55 +00:00
|
|
|
export const platform = mocked(_platform);
|
|
|
|
|
2019-12-17 05:56:42 +00:00
|
|
|
// Required because of isolatedModules
|
|
|
|
export type RenovateConfig = _RenovateConfig;
|
|
|
|
|
2019-12-09 11:42:55 +00:00
|
|
|
export const defaultConfig = getConfig();
|
2019-12-17 05:56:42 +00:00
|
|
|
|
|
|
|
export { getConfig };
|
2020-03-07 10:27:10 +00:00
|
|
|
|
|
|
|
export function getName(file: string): string {
|
|
|
|
const [, name] = /lib\/(.*?)\.spec\.ts$/.exec(file.replace(/\\/g, '/'));
|
|
|
|
return name;
|
|
|
|
}
|
2020-04-03 07:44:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Can be used to search and replace strings in jest snapshots.
|
|
|
|
* @example
|
|
|
|
* expect.addSnapshotSerializer(
|
|
|
|
* replacingSerializer(upath.toUnix(gradleDir.path), 'localDir')
|
|
|
|
* );
|
|
|
|
*/
|
|
|
|
export const replacingSerializer = (
|
|
|
|
search: string,
|
|
|
|
replacement: string
|
|
|
|
): jest.SnapshotSerializerPlugin => ({
|
|
|
|
test: value => typeof value === 'string' && value.includes(search),
|
|
|
|
serialize: (val, config, indent, depth, refs, printer) => {
|
|
|
|
const replaced = (val as string).replace(search, replacement);
|
|
|
|
return printer(replaced, config, indent, depth, refs);
|
|
|
|
},
|
|
|
|
});
|