2020-02-04 22:02:52 +08:00
|
|
|
<html>
|
|
|
|
|
|
|
|
<head>
|
|
|
|
<meta charset="utf-8">
|
|
|
|
<title>VSCode Tests</title>
|
2020-02-07 16:51:24 +08:00
|
|
|
<link href="../../../node_modules/mocha/mocha.css" rel="stylesheet" />
|
2020-02-04 22:02:52 +08:00
|
|
|
</head>
|
|
|
|
|
|
|
|
<body>
|
|
|
|
<div id="mocha"></div>
|
2020-02-07 16:51:24 +08:00
|
|
|
<script src="../../../node_modules/mocha/mocha.js"></script>
|
2020-02-04 22:02:52 +08:00
|
|
|
<script>
|
|
|
|
// !!! DO NOT CHANGE !!!
|
|
|
|
// Our unit tests may run in environments without
|
|
|
|
// display (e.g. from builds) and tests may by
|
|
|
|
// accident bring up native dialogs or even open
|
|
|
|
// windows. This we cannot allow as it may crash
|
|
|
|
// the test run.
|
|
|
|
// !!! DO NOT CHANGE !!!
|
|
|
|
window.open = function () { throw new Error('window.open() is not supported in tests!'); };
|
|
|
|
window.alert = function () { throw new Error('window.alert() is not supported in tests!'); }
|
|
|
|
window.confirm = function () { throw new Error('window.confirm() is not supported in tests!'); }
|
|
|
|
|
|
|
|
// Ignore uncaught cancelled promise errors
|
|
|
|
window.addEventListener('unhandledrejection', e => {
|
|
|
|
const name = e && e.reason && e.reason.name;
|
|
|
|
|
|
|
|
if (name === 'Canceled') {
|
|
|
|
e.preventDefault();
|
|
|
|
e.stopPropagation();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2023-05-12 19:02:15 +08:00
|
|
|
const urlParams = new URLSearchParams(window.location.search);
|
|
|
|
const isCI = urlParams.get('ci');
|
|
|
|
|
2020-02-04 22:02:52 +08:00
|
|
|
mocha.setup({
|
|
|
|
ui: 'tdd',
|
2023-05-12 19:02:15 +08:00
|
|
|
timeout: isCI ? 30000 : 5000
|
2020-02-04 22:02:52 +08:00
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<script>
|
2020-02-10 19:44:28 +08:00
|
|
|
const isBuild = urlParams.get('build');
|
2024-08-30 16:31:46 +08:00
|
|
|
const out = !!isBuild ? 'out-build' : 'out';
|
|
|
|
const tasks =[];
|
2020-02-10 19:44:28 +08:00
|
|
|
|
2020-02-04 22:02:52 +08:00
|
|
|
// configure loader
|
|
|
|
const baseUrl = window.location.href;
|
2024-08-30 16:31:46 +08:00
|
|
|
|
|
|
|
// generate import map
|
|
|
|
const importMapParent = document.currentScript.parentNode;
|
|
|
|
const importMap = {
|
|
|
|
imports: {
|
|
|
|
vs: new URL(`../../../${out}/vs`, baseUrl).href,
|
2024-10-02 17:55:17 +08:00
|
|
|
assert: new URL('../assert.js', baseUrl).href,
|
2024-08-30 16:31:46 +08:00
|
|
|
sinon: new URL('../../../node_modules/sinon/pkg/sinon-esm.js', baseUrl).href,
|
|
|
|
'sinon-test': new URL('../../../node_modules/sinon-test/dist/sinon-test-es.js', baseUrl).href,
|
2023-11-02 21:34:09 +08:00
|
|
|
'@xterm/xterm': new URL('../../../node_modules/@xterm/xterm/lib/xterm.js', baseUrl).href,
|
2022-01-14 14:28:41 +08:00
|
|
|
'@vscode/iconv-lite-umd': new URL('../../../node_modules/@vscode/iconv-lite-umd/lib/iconv-lite-umd.js', baseUrl).href,
|
2020-07-03 21:55:44 +08:00
|
|
|
jschardet: new URL('../../../node_modules/jschardet/dist/jschardet.min.js', baseUrl).href
|
2020-02-04 22:02:52 +08:00
|
|
|
}
|
2024-08-30 16:31:46 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// ---- CSS tricks
|
|
|
|
|
|
|
|
const cssDataBase64 = urlParams.get('_devCssData');
|
|
|
|
if (typeof cssDataBase64 === 'string') {
|
|
|
|
|
|
|
|
const style = document.createElement('style');
|
|
|
|
style.type = 'text/css';
|
|
|
|
document.head.appendChild(style);
|
|
|
|
|
|
|
|
globalThis._VSCODE_CSS_LOAD = function (url) {
|
|
|
|
// debugger;
|
|
|
|
style.sheet.insertRule(`@import url(${url});`);
|
|
|
|
};
|
|
|
|
|
|
|
|
const cssData = Uint8Array.from(atob(cssDataBase64), c => c.charCodeAt(0));
|
|
|
|
tasks.push(new Response(new Blob([cssData], {type:'application/octet-binary'}).stream().pipeThrough(new DecompressionStream('gzip'))).text().then(value => {
|
|
|
|
const cssModules = value.split(',');
|
|
|
|
for (const cssModule of cssModules) {
|
|
|
|
const cssUrl = new URL(`../../../${out}/${cssModule}`, baseUrl).href;
|
|
|
|
const jsSrc = `globalThis._VSCODE_CSS_LOAD('${cssUrl}');\n`;
|
|
|
|
const blob = new Blob([jsSrc], { type: 'application/javascript' });
|
|
|
|
importMap.imports[cssUrl] = URL.createObjectURL(blob);
|
|
|
|
}
|
|
|
|
}).catch(err => {
|
|
|
|
console.error(err);
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
|
|
|
const initPromise = Promise.allSettled(tasks).then(() => {
|
|
|
|
|
|
|
|
const rawImportMap = JSON.stringify(importMap, undefined, 2);
|
|
|
|
const importMapScript = document.createElement('script');
|
|
|
|
importMapScript.type = 'importmap';
|
|
|
|
importMapScript.textContent = rawImportMap;
|
|
|
|
importMapParent.appendChild(importMapScript);
|
|
|
|
|
|
|
|
}).then(() => {
|
|
|
|
const bootstrapScript = document.createElement('script');
|
|
|
|
bootstrapScript.type = 'module';
|
|
|
|
bootstrapScript.textContent = document.getElementById('bootstrap').textContent
|
|
|
|
document.getElementById('bootstrap').remove();
|
|
|
|
document.body.append(bootstrapScript);
|
2020-02-04 22:02:52 +08:00
|
|
|
});
|
|
|
|
|
2024-08-30 16:31:46 +08:00
|
|
|
// set up require
|
|
|
|
|
|
|
|
globalThis._VSCODE_FILE_ROOT = new URL('../../../src', baseUrl).href;
|
|
|
|
globalThis.require = {
|
|
|
|
paths: {
|
|
|
|
xterm: new URL('../../../node_modules/xterm', baseUrl).href,
|
|
|
|
'@vscode/iconv-lite-umd': new URL('../../../node_modules/@vscode/iconv-lite-umd', baseUrl).href,
|
|
|
|
jschardet: new URL('../../../node_modules/jschardet', baseUrl).href
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
2024-08-31 00:12:48 +08:00
|
|
|
|
2020-02-04 22:02:52 +08:00
|
|
|
<script>
|
|
|
|
function serializeSuite(suite) {
|
|
|
|
return {
|
|
|
|
root: suite.root,
|
|
|
|
suites: suite.suites.map(serializeSuite),
|
|
|
|
tests: suite.tests.map(serializeRunnable),
|
|
|
|
title: suite.title,
|
|
|
|
fullTitle: suite.fullTitle(),
|
2020-12-18 02:16:42 +08:00
|
|
|
titlePath: suite.titlePath(),
|
2020-02-04 22:02:52 +08:00
|
|
|
timeout: suite.timeout(),
|
|
|
|
retries: suite.retries(),
|
|
|
|
slow: suite.slow(),
|
|
|
|
bail: suite.bail()
|
|
|
|
};
|
|
|
|
}
|
|
|
|
function serializeRunnable(runnable) {
|
|
|
|
return {
|
|
|
|
title: runnable.title,
|
2020-12-18 02:16:42 +08:00
|
|
|
titlePath: runnable.titlePath(),
|
2020-02-04 22:02:52 +08:00
|
|
|
fullTitle: runnable.fullTitle(),
|
|
|
|
async: runnable.async,
|
|
|
|
slow: runnable.slow(),
|
|
|
|
speed: runnable.speed,
|
2021-07-13 08:28:01 +08:00
|
|
|
duration: runnable.duration,
|
|
|
|
currentRetry: runnable.currentRetry(),
|
2020-02-04 22:02:52 +08:00
|
|
|
};
|
|
|
|
}
|
|
|
|
function serializeError(err) {
|
|
|
|
return {
|
|
|
|
message: err.message,
|
|
|
|
stack: err.stack,
|
|
|
|
actual: err.actual,
|
|
|
|
expected: err.expected,
|
|
|
|
uncaught: err.uncaught,
|
|
|
|
showDiff: err.showDiff,
|
|
|
|
inspect: typeof err.inspect === 'function' ? err.inspect() : ''
|
|
|
|
};
|
|
|
|
}
|
|
|
|
function PlaywrightReporter(runner) {
|
|
|
|
runner.on('start', () => window.mocha_report('start'));
|
|
|
|
runner.on('end', () => window.mocha_report('end'));
|
|
|
|
runner.on('suite', suite => window.mocha_report('suite', serializeSuite(suite)));
|
|
|
|
runner.on('suite end', suite => window.mocha_report('suite end', serializeSuite(suite)));
|
|
|
|
runner.on('test', test => window.mocha_report('test', serializeRunnable(test)));
|
|
|
|
runner.on('test end', test => window.mocha_report('test end', serializeRunnable(test)));
|
|
|
|
runner.on('hook', hook => window.mocha_report('hook', serializeRunnable(hook)));
|
|
|
|
runner.on('hook end', hook => window.mocha_report('hook end', serializeRunnable(hook)));
|
|
|
|
runner.on('pass', test => window.mocha_report('pass', serializeRunnable(test)));
|
|
|
|
runner.on('fail', (test, err) => window.mocha_report('fail', serializeRunnable(test), serializeError(err)));
|
|
|
|
runner.on('pending', test => window.mocha_report('pending', serializeRunnable(test)));
|
|
|
|
};
|
|
|
|
|
2023-09-22 05:48:21 +08:00
|
|
|
const remoteMethods = [
|
|
|
|
'__readFileInTests',
|
|
|
|
'__writeFileInTests',
|
|
|
|
'__readDirInTests',
|
|
|
|
'__unlinkInTests',
|
|
|
|
'__mkdirPInTests',
|
|
|
|
];
|
|
|
|
|
|
|
|
for (const method of remoteMethods) {
|
|
|
|
const prefix = window.location.pathname.split('/')[1];
|
|
|
|
globalThis[method] = async (...args) => {
|
|
|
|
const res = await fetch(`/${prefix}/remoteMethod/${method}`, {
|
|
|
|
body: JSON.stringify(args),
|
|
|
|
method: 'POST',
|
|
|
|
headers: { 'Content-Type': 'application/json' }
|
|
|
|
});
|
|
|
|
|
|
|
|
return res.json();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-08-16 03:03:51 +08:00
|
|
|
async function loadModules(modules) {
|
|
|
|
for (const file of modules) {
|
|
|
|
mocha.suite.emit(Mocha.Suite.constants.EVENT_FILE_PRE_REQUIRE, globalThis, file, mocha);
|
2024-08-30 16:31:46 +08:00
|
|
|
const m = await new Promise((resolve, reject) => import(`../../../${out}/${file}.js`).then(resolve, err => {
|
2024-08-31 00:12:48 +08:00
|
|
|
console.log("BAD " + file + JSON.stringify(err, undefined, '\t'));
|
2023-08-16 03:03:51 +08:00
|
|
|
resolve({});
|
|
|
|
}));
|
|
|
|
mocha.suite.emit(Mocha.Suite.constants.EVENT_FILE_REQUIRE, m, file, mocha);
|
|
|
|
mocha.suite.emit(Mocha.Suite.constants.EVENT_FILE_POST_REQUIRE, globalThis, file, mocha);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-08-30 16:31:46 +08:00
|
|
|
let _resolveTestData;
|
|
|
|
let _resolveTestRun;
|
|
|
|
globalThis._VSCODE_TEST_RUN = new Promise(resolve => _resolveTestData = resolve)
|
2021-07-13 08:28:01 +08:00
|
|
|
|
2024-08-30 16:31:46 +08:00
|
|
|
window.loadAndRun = async function loadAndRun(data, manual = false) {
|
|
|
|
_resolveTestData({data, manual})
|
|
|
|
return new Promise(resolve => _resolveTestRun = resolve);
|
2020-02-04 22:02:52 +08:00
|
|
|
}
|
2020-02-05 22:22:02 +08:00
|
|
|
|
2024-08-30 16:31:46 +08:00
|
|
|
const modules = new URL(window.location.href).searchParams.getAll('m');
|
2020-02-07 16:51:24 +08:00
|
|
|
if (Array.isArray(modules) && modules.length > 0) {
|
2020-02-05 22:22:02 +08:00
|
|
|
console.log('MANUALLY running tests', modules);
|
|
|
|
|
2024-08-30 16:31:46 +08:00
|
|
|
loadAndRun(modules, true).then(() => console.log('done'), err => console.log(err));
|
2020-02-05 22:22:02 +08:00
|
|
|
}
|
2020-02-04 22:02:52 +08:00
|
|
|
</script>
|
2024-08-30 16:31:46 +08:00
|
|
|
|
|
|
|
<script type="text" id="bootstrap">
|
|
|
|
const {data: {modules, grep}, manual} = await globalThis._VSCODE_TEST_RUN
|
|
|
|
|
|
|
|
// load
|
|
|
|
await loadModules(modules);
|
|
|
|
|
|
|
|
// run
|
|
|
|
await new Promise((resolve, reject) => {
|
|
|
|
if (grep) {
|
|
|
|
mocha.grep(grep);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!manual) {
|
|
|
|
mocha.reporter(PlaywrightReporter);
|
|
|
|
}
|
|
|
|
mocha.run(failCount => resolve(failCount === 0));
|
|
|
|
});
|
|
|
|
|
|
|
|
_resolveTestRun();
|
|
|
|
</script>
|
2020-02-04 22:02:52 +08:00
|
|
|
</body>
|
|
|
|
|
|
|
|
</html>
|