mirror of
https://github.com/zhigang1992/create-react-app.git
synced 2026-06-17 02:51:08 +08:00
151 lines
4.4 KiB
JavaScript
151 lines
4.4 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
import initDOM, { resourceLoader } from './initDOM';
|
|
import url from 'url';
|
|
|
|
const matchCSS = (doc, regexes) => {
|
|
if (process.env.E2E_FILE) {
|
|
const elements = doc.getElementsByTagName('link');
|
|
let href = '';
|
|
for (const elem of elements) {
|
|
if (elem.rel === 'stylesheet') {
|
|
href = elem.href;
|
|
}
|
|
}
|
|
resourceLoader({ url: url.parse(href) }, (_, textContent) => {
|
|
for (const regex of regexes) {
|
|
expect(textContent).toMatch(regex);
|
|
}
|
|
});
|
|
} else {
|
|
for (let i = 0; i < regexes.length; ++i) {
|
|
expect(
|
|
doc.getElementsByTagName('style')[i].textContent.replace(/\s/g, '')
|
|
).toMatch(regexes[i]);
|
|
}
|
|
}
|
|
};
|
|
|
|
describe('Integration', () => {
|
|
describe('Webpack plugins', () => {
|
|
it('css inclusion', async () => {
|
|
const doc = await initDOM('css-inclusion');
|
|
matchCSS(doc, [
|
|
/html\{/,
|
|
/#feature-css-inclusion\{background:.+;color:.+}/,
|
|
]);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('css modules inclusion', async () => {
|
|
const doc = await initDOM('css-modules-inclusion');
|
|
matchCSS(doc, [
|
|
/.+style_cssModulesInclusion__.+\{background:.+;color:.+}/,
|
|
/.+assets_cssModulesIndexInclusion__.+\{background:.+;color:.+}/,
|
|
]);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('scss inclusion', async () => {
|
|
const doc = await initDOM('scss-inclusion');
|
|
matchCSS(doc, [/#feature-scss-inclusion\{background:.+;color:.+}/]);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('scss modules inclusion', async () => {
|
|
const doc = await initDOM('scss-modules-inclusion');
|
|
matchCSS(doc, [
|
|
/.+scss-styles_scssModulesInclusion.+\{background:.+;color:.+}/,
|
|
/.+assets_scssModulesIndexInclusion.+\{background:.+;color:.+}/,
|
|
]);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('sass inclusion', async () => {
|
|
const doc = await initDOM('sass-inclusion');
|
|
matchCSS(doc, [/#feature-sass-inclusion\{background:.+;color:.+}/]);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('sass modules inclusion', async () => {
|
|
const doc = await initDOM('sass-modules-inclusion');
|
|
matchCSS(doc, [
|
|
/.+sass-styles_sassModulesInclusion.+\{background:.+;color:.+}/,
|
|
/.+assets_sassModulesIndexInclusion.+\{background:.+;color:.+}/,
|
|
]);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('image inclusion', async () => {
|
|
const doc = await initDOM('image-inclusion');
|
|
|
|
expect(doc.getElementById('feature-image-inclusion').src).toMatch(
|
|
/^data:image\/jpeg;base64.+==$/
|
|
);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('no ext inclusion', async () => {
|
|
const doc = await initDOM('no-ext-inclusion');
|
|
|
|
expect(doc.getElementById('feature-no-ext-inclusion').href).toMatch(
|
|
/\/static\/media\/aFileWithoutExt\.[a-f0-9]{8}\.bin$/
|
|
);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('json inclusion', async () => {
|
|
const doc = await initDOM('json-inclusion');
|
|
|
|
expect(doc.getElementById('feature-json-inclusion').textContent).toBe(
|
|
'This is an abstract.'
|
|
);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('linked modules', async () => {
|
|
const doc = await initDOM('linked-modules');
|
|
|
|
expect(doc.getElementById('feature-linked-modules').textContent).toBe(
|
|
'2.0.0'
|
|
);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('svg inclusion', async () => {
|
|
const doc = await initDOM('svg-inclusion');
|
|
expect(doc.getElementById('feature-svg-inclusion').src).toMatch(
|
|
/\/static\/media\/logo\..+\.svg$/
|
|
);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('svg component', async () => {
|
|
const doc = await initDOM('svg-component');
|
|
|
|
expect(doc.getElementById('feature-svg-component').textContent).toBe('');
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('svg in css', async () => {
|
|
const doc = await initDOM('svg-in-css');
|
|
matchCSS(doc, [/\/static\/media\/logo\..+\.svg/]);
|
|
doc.defaultView.close();
|
|
});
|
|
|
|
it('unknown ext inclusion', async () => {
|
|
const doc = await initDOM('unknown-ext-inclusion');
|
|
|
|
expect(doc.getElementById('feature-unknown-ext-inclusion').href).toMatch(
|
|
/\/static\/media\/aFileWithExt\.[a-f0-9]{8}\.unknown$/
|
|
);
|
|
doc.defaultView.close();
|
|
});
|
|
});
|
|
});
|