2019-03-11 09:47:36 -04:00
|
|
|
import fs from 'fs';
|
|
|
|
import path from 'path';
|
|
|
|
|
|
|
|
import { ErrorWithStack } from 'jest-util';
|
|
|
|
|
2019-03-27 09:50:11 -04:00
|
|
|
export function getFixture(relativePath) {
|
2019-07-17 18:47:33 -04:00
|
|
|
const basePath = relativePath.startsWith('static/')
|
|
|
|
? global.staticFixturesBasePath
|
|
|
|
: global.fixturesBasePath;
|
|
|
|
const absolutePath = path.join(basePath, relativePath);
|
2019-03-11 09:47:36 -04:00
|
|
|
if (!fs.existsSync(absolutePath)) {
|
|
|
|
throw new ErrorWithStack(
|
|
|
|
`Fixture file ${relativePath} does not exist.
|
|
|
|
|
2019-07-17 18:17:37 -04:00
|
|
|
Did you run bin/rake frontend:fixtures?`,
|
2019-03-27 09:50:11 -04:00
|
|
|
getFixture,
|
2019-03-11 09:47:36 -04:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-03-27 09:50:11 -04:00
|
|
|
return fs.readFileSync(absolutePath, 'utf8');
|
2019-03-11 09:47:36 -04:00
|
|
|
}
|
2019-03-27 09:50:11 -04:00
|
|
|
|
|
|
|
export const getJSONFixture = relativePath => JSON.parse(getFixture(relativePath));
|
|
|
|
|
|
|
|
export const resetHTMLFixture = () => {
|
|
|
|
document.body.textContent = '';
|
|
|
|
};
|
|
|
|
|
|
|
|
export const setHTMLFixture = (htmlContent, resetHook = afterEach) => {
|
|
|
|
document.body.outerHTML = htmlContent;
|
|
|
|
resetHook(resetHTMLFixture);
|
|
|
|
};
|
|
|
|
|
|
|
|
export const loadHTMLFixture = (relativePath, resetHook = afterEach) => {
|
|
|
|
const fileContent = getFixture(relativePath);
|
|
|
|
setHTMLFixture(fileContent, resetHook);
|
|
|
|
};
|