mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 13:48:50 +00:00
Switch to @types/vscode
and vscode-test
The old `vscode` package is outdated and it is recommened to switch to these two new packages. This also solves a problem of a missing `.d.ts` for `vscode` in Nixos.
This commit is contained in:
parent
0c35d82329
commit
b58f84626f
6 changed files with 802 additions and 450 deletions
1146
editors/code/package-lock.json
generated
1146
editors/code/package-lock.json
generated
File diff suppressed because it is too large
Load diff
|
@ -13,18 +13,17 @@
|
||||||
"Other"
|
"Other"
|
||||||
],
|
],
|
||||||
"engines": {
|
"engines": {
|
||||||
"vscode": "^1.33.0"
|
"vscode": "^1.36.0"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"vscode:prepublish": "npm run compile",
|
"vscode:prepublish": "npm run compile",
|
||||||
"package": "vsce package",
|
"package": "vsce package",
|
||||||
"compile": "tsc -p ./ && shx cp src/utils/terminateProcess.sh out/utils/terminateProcess.sh",
|
"compile": "tsc -p ./ && shx cp src/utils/terminateProcess.sh out/utils/terminateProcess.sh",
|
||||||
"watch": "tsc -watch -p ./",
|
"watch": "tsc -watch -p ./",
|
||||||
"postinstall": "node ./node_modules/vscode/bin/install",
|
|
||||||
"fix": "prettier **/*.{json,ts} --write && tslint --project . --fix",
|
"fix": "prettier **/*.{json,ts} --write && tslint --project . --fix",
|
||||||
"lint": "tslint --project .",
|
"lint": "tslint --project .",
|
||||||
"test": "node node_modules/vscode/bin/test",
|
|
||||||
"prettier": "prettier **/*.{json,ts}",
|
"prettier": "prettier **/*.{json,ts}",
|
||||||
|
"test": "node ./out/test/runTest.js",
|
||||||
"travis": "npm run compile && npm run test && npm run lint && npm run prettier -- --write && git diff --exit-code"
|
"travis": "npm run compile && npm run test && npm run lint && npm run prettier -- --write && git diff --exit-code"
|
||||||
},
|
},
|
||||||
"prettier": {
|
"prettier": {
|
||||||
|
@ -39,13 +38,17 @@
|
||||||
"@types/mocha": "^5.2.7",
|
"@types/mocha": "^5.2.7",
|
||||||
"@types/node": "^10.14.13",
|
"@types/node": "^10.14.13",
|
||||||
"@types/seedrandom": "^2.4.28",
|
"@types/seedrandom": "^2.4.28",
|
||||||
|
"@types/glob": "^7.1.1",
|
||||||
|
"@types/vscode": "^1.36.0",
|
||||||
|
"glob": "^7.1.4",
|
||||||
|
"mocha": "^6.2.0",
|
||||||
"prettier": "^1.18.2",
|
"prettier": "^1.18.2",
|
||||||
"shx": "^0.3.1",
|
"shx": "^0.3.1",
|
||||||
"tslint": "^5.18.0",
|
"tslint": "^5.18.0",
|
||||||
"tslint-config-prettier": "^1.18.0",
|
"tslint-config-prettier": "^1.18.0",
|
||||||
"typescript": "^3.5.3",
|
"typescript": "^3.5.3",
|
||||||
"vsce": "^1.66.0",
|
"vsce": "^1.66.0",
|
||||||
"vscode": "^1.1.35"
|
"vscode-test": "^1.2.0"
|
||||||
},
|
},
|
||||||
"activationEvents": [
|
"activationEvents": [
|
||||||
"onLanguage:rust",
|
"onLanguage:rust",
|
||||||
|
|
|
@ -1,22 +0,0 @@
|
||||||
//
|
|
||||||
// PLEASE DO NOT MODIFY / DELETE UNLESS YOU KNOW WHAT YOU ARE DOING
|
|
||||||
//
|
|
||||||
// This file is providing the test runner to use when running extension tests.
|
|
||||||
// By default the test runner in use is Mocha based.
|
|
||||||
//
|
|
||||||
// You can provide your own test runner if you want to override it by exporting
|
|
||||||
// a function run(testRoot: string, clb: (error:Error) => void) that the extension
|
|
||||||
// host can call to run the tests. The test runner is expected to use console.log
|
|
||||||
// to report the results back to the caller. When the tests are finished, return
|
|
||||||
// a possible error to the callback or null if none.
|
|
||||||
|
|
||||||
import * as testRunner from 'vscode/lib/testrunner';
|
|
||||||
|
|
||||||
// You can directly control Mocha options by uncommenting the following lines
|
|
||||||
// See https://github.com/mochajs/mocha/wiki/Using-mocha-programmatically#set-options for more info
|
|
||||||
testRunner.configure({
|
|
||||||
ui: 'bdd', // the TDD UI is being used in extension.test.ts (suite, test, etc.)
|
|
||||||
useColors: true // colored output from test results
|
|
||||||
});
|
|
||||||
|
|
||||||
module.exports = testRunner;
|
|
22
editors/code/src/test/runTest.ts
Normal file
22
editors/code/src/test/runTest.ts
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
import * as path from 'path';
|
||||||
|
|
||||||
|
import { runTests } from 'vscode-test';
|
||||||
|
|
||||||
|
async function main() {
|
||||||
|
try {
|
||||||
|
// The folder containing the Extension Manifest package.json
|
||||||
|
// Passed to `--extensionDevelopmentPath`
|
||||||
|
const extensionDevelopmentPath = path.resolve(__dirname, '../../');
|
||||||
|
|
||||||
|
// The path to the extension test runner script
|
||||||
|
// Passed to --extensionTestsPath
|
||||||
|
const extensionTestsPath = path.resolve(__dirname, './utils/index');
|
||||||
|
|
||||||
|
// Download VS Code, unzip it and run the integration test
|
||||||
|
await runTests({ extensionDevelopmentPath, extensionTestsPath });
|
||||||
|
} catch (err) {
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
main();
|
49
editors/code/src/test/utils/index.ts
Normal file
49
editors/code/src/test/utils/index.ts
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
//
|
||||||
|
// PLEASE DO NOT MODIFY / DELETE UNLESS YOU KNOW WHAT YOU ARE DOING
|
||||||
|
//
|
||||||
|
// This file is providing the test runner to use when running extension tests.
|
||||||
|
// By default the test runner in use is Mocha based.
|
||||||
|
//
|
||||||
|
// You can provide your own test runner if you want to override it by exporting
|
||||||
|
// a function run(testRoot: string, clb: (error:Error) => void) that the extension
|
||||||
|
// host can call to run the tests. The test runner is expected to use console.log
|
||||||
|
// to report the results back to the caller. When the tests are finished, return
|
||||||
|
// a possible error to the callback or null if none.
|
||||||
|
|
||||||
|
import * as glob from 'glob';
|
||||||
|
import * as Mocha from 'mocha';
|
||||||
|
import * as path from 'path';
|
||||||
|
|
||||||
|
export function run(): Promise<void> {
|
||||||
|
// Create the mocha test
|
||||||
|
const mocha = new Mocha({
|
||||||
|
ui: 'bdd'
|
||||||
|
});
|
||||||
|
mocha.useColors(true);
|
||||||
|
|
||||||
|
const testsRoot = __dirname;
|
||||||
|
|
||||||
|
return new Promise((c, e) => {
|
||||||
|
glob('**/**.test.js', { cwd: testsRoot }, (err, files) => {
|
||||||
|
if (err) {
|
||||||
|
return e(err);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add files to the test suite
|
||||||
|
files.forEach(f => mocha.addFile(path.resolve(testsRoot, f)));
|
||||||
|
|
||||||
|
try {
|
||||||
|
// Run the mocha test
|
||||||
|
mocha.run(failures => {
|
||||||
|
if (failures > 0) {
|
||||||
|
e(new Error(`${failures} tests failed.`));
|
||||||
|
} else {
|
||||||
|
c();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} catch (err) {
|
||||||
|
e(err);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
|
@ -64,7 +64,7 @@ function mapLevelToSeverity(s: string): vscode.DiagnosticSeverity {
|
||||||
* Converts a Rust span to a VsCode location
|
* Converts a Rust span to a VsCode location
|
||||||
*/
|
*/
|
||||||
function mapSpanToLocation(span: RustDiagnosticSpan): vscode.Location {
|
function mapSpanToLocation(span: RustDiagnosticSpan): vscode.Location {
|
||||||
const fileName = path.join(vscode.workspace.rootPath!, span.file_name);
|
const fileName = path.join(vscode.workspace.rootPath || '', span.file_name);
|
||||||
const fileUri = vscode.Uri.file(fileName);
|
const fileUri = vscode.Uri.file(fileName);
|
||||||
|
|
||||||
const range = new vscode.Range(
|
const range = new vscode.Range(
|
||||||
|
|
Loading…
Reference in a new issue