From 021768d9618fbbebc274c23833fc43558998cc1a Mon Sep 17 00:00:00 2001
From: Jake Bailey <5341706+jakebailey@users.noreply.github.com>
Date: Thu, 26 May 2022 17:00:27 -0700
Subject: [PATCH] Convert require calls to imports
---
src/cancellationToken/cancellationToken.ts | 2 +-
src/harness/findUpDir.ts | 4 ++--
src/harness/harnessGlobals.ts | 20 ++++++++-----------
src/instrumenter/instrumenter.ts | 4 ++--
src/testRunner/externalCompileRunner.ts | 8 ++++----
.../unittests/services/languageService.ts | 4 ++--
src/testRunner/unittests/tsserver/session.ts | 4 ++--
src/typingsInstaller/nodeTypingsInstaller.ts | 13 +++---------
src/watchGuard/watchGuard.ts | 3 ++-
9 files changed, 26 insertions(+), 36 deletions(-)
diff --git a/src/cancellationToken/cancellationToken.ts b/src/cancellationToken/cancellationToken.ts
index aaa19750b8710..57c82e7522fa6 100644
--- a/src/cancellationToken/cancellationToken.ts
+++ b/src/cancellationToken/cancellationToken.ts
@@ -1,6 +1,6 @@
///
-import fs = require("fs");
+import * as fs from "fs";
interface ServerCancellationToken {
isCancellationRequested(): boolean;
diff --git a/src/harness/findUpDir.ts b/src/harness/findUpDir.ts
index 3a43a5c691703..1df1706e41091 100644
--- a/src/harness/findUpDir.ts
+++ b/src/harness/findUpDir.ts
@@ -1,5 +1,5 @@
-const { join, resolve, dirname } = require("path") as typeof import("path");
-const { existsSync } = require("fs") as typeof import("fs");
+import { existsSync } from "fs";
+import { dirname, join, resolve } from "path";
// search directories upward to avoid hard-wired paths based on the
// build tree (same as scripts/build/findUpDir.js)
diff --git a/src/harness/harnessGlobals.ts b/src/harness/harnessGlobals.ts
index 26768d28ec3cc..30432a8294b62 100644
--- a/src/harness/harnessGlobals.ts
+++ b/src/harness/harnessGlobals.ts
@@ -1,19 +1,15 @@
-import { isArray } from "../compiler/core";
+import * as chai from "chai";
-// Block scoped definitions work poorly for global variables, temporarily enable var
-/* eslint-disable no-var */
+import { isArray } from "../compiler/core";
// this will work in the browser via browserify
declare global {
// Module transform: converted from ambient declaration
- var assert: typeof _chai.assert;
+ var assert: typeof chai.assert;
+ var expect: typeof chai.expect;
}
-declare global {
- // Module transform: converted from ambient declaration
- var expect: typeof _chai.expect;
-}
-var _chai: typeof import("chai") = require("chai");
-assert = _chai.assert;
+
+globalThis.assert = chai.assert;
{
// chai's builtin `assert.isFalse` is featureful but slow - we don't use those features,
// so we'll just overwrite it as an alterative to migrating a bunch of code off of chai
@@ -39,7 +35,7 @@ assert = _chai.assert;
}
};
}
-expect = _chai.expect;
-/* eslint-enable no-var */
+globalThis.expect = chai.expect;
+
// empty ts namespace so this file is included in the `ts.ts` namespace file generated by the module swapover
// This way, everything that ends up importing `ts` downstream also imports this file and picks up its augmentation
\ No newline at end of file
diff --git a/src/instrumenter/instrumenter.ts b/src/instrumenter/instrumenter.ts
index c7cbb8d3ec855..641d1734561e4 100644
--- a/src/instrumenter/instrumenter.ts
+++ b/src/instrumenter/instrumenter.ts
@@ -1,5 +1,5 @@
-import fs = require("fs");
-import path = require("path");
+import * as fs from "fs";
+import * as path from "path";
function instrumentForRecording(fn: string, tscPath: string) {
instrument(tscPath, `
diff --git a/src/testRunner/externalCompileRunner.ts b/src/testRunner/externalCompileRunner.ts
index d0ca9a09d13d4..d7741d1bd3cf8 100644
--- a/src/testRunner/externalCompileRunner.ts
+++ b/src/testRunner/externalCompileRunner.ts
@@ -1,3 +1,7 @@
+import * as del from "del";
+import * as fs from "fs";
+import * as path from "path";
+
import { compareStringsCaseSensitive, compareValues, flatten, stringContains } from "../compiler/core";
import { Debug } from "../compiler/debug";
import { comparePathsCaseSensitive } from "../compiler/path";
@@ -6,10 +10,6 @@ import { RunnerBase, TestRunnerKind } from "../harness/runnerbase";
import * as Harness from "./_namespaces/Harness";
import { isWorker } from "./runner";
-const fs: typeof import("fs") = require("fs");
-const path: typeof import("path") = require("path");
-const del: typeof import("del") = require("del");
-
interface ExecResult {
stdout: Buffer;
stderr: Buffer;
diff --git a/src/testRunner/unittests/services/languageService.ts b/src/testRunner/unittests/services/languageService.ts
index 845d0cd53b654..da25b7ecd09e3 100644
--- a/src/testRunner/unittests/services/languageService.ts
+++ b/src/testRunner/unittests/services/languageService.ts
@@ -1,3 +1,5 @@
+import { expect } from "chai";
+
import { getParsedCommandLineOfConfigFile } from "../../../compiler/commandLineParser";
import { emptyArray, noop, returnTrue } from "../../../compiler/core";
import { Map } from "../../../compiler/corePublic";
@@ -9,8 +11,6 @@ import * as ts from "../../_namespaces/ts";
import { projectRoot } from "../tscWatch/helpers";
import { createServerHost, libFile } from "../tsserver/helpers";
-const _chai: typeof import("chai") = require("chai");
-const expect: typeof _chai.expect = _chai.expect;
describe("unittests:: services:: languageService", () => {
const files: {[index: string]: string} = {
"foo.ts": `import Vue from "./vue";
diff --git a/src/testRunner/unittests/tsserver/session.ts b/src/testRunner/unittests/tsserver/session.ts
index b4c4c6540f550..95cf0a202ad8d 100644
--- a/src/testRunner/unittests/tsserver/session.ts
+++ b/src/testRunner/unittests/tsserver/session.ts
@@ -1,3 +1,5 @@
+import { expect } from "chai";
+
import { AnyFunction, noop, returnUndefined } from "../../../compiler/core";
import { Map, version } from "../../../compiler/corePublic";
import { Debug } from "../../../compiler/debug";
@@ -17,8 +19,6 @@ import { FileTextChanges, IndentStyle } from "../../../services/types";
import * as Harness from "../../_namespaces/Harness";
import { createHasErrorMessageLogger, nullLogger } from "./helpers";
-const _chai: typeof import("chai") = require("chai");
-const expect: typeof _chai.expect = _chai.expect;
let lastWrittenToHost: string;
const noopFileWatcher: FileWatcher = { close: noop };
const mockHost: ServerHost = {
diff --git a/src/typingsInstaller/nodeTypingsInstaller.ts b/src/typingsInstaller/nodeTypingsInstaller.ts
index 1320a9a8a5825..eb8feab955a11 100644
--- a/src/typingsInstaller/nodeTypingsInstaller.ts
+++ b/src/typingsInstaller/nodeTypingsInstaller.ts
@@ -1,3 +1,6 @@
+import * as fs from "fs";
+import * as path from "path";
+
import { createGetCanonicalFileName, getEntries, stringContains } from "../compiler/core";
import { ESMap, Map, MapLike, version } from "../compiler/corePublic";
import { Debug } from "../compiler/debug";
@@ -14,16 +17,6 @@ import {
installNpmPackages, Log, RequestCompletedAction, TypingsInstaller,
} from "../typingsInstallerCore/typingsInstaller";
-const fs: {
- appendFileSync(file: string, content: string): void
-} = require("fs");
-
-const path: {
- join(...parts: string[]): string;
- dirname(path: string): string;
- basename(path: string, extension?: string): string;
-} = require("path");
-
class FileLog implements Log {
constructor(private logFile: string | undefined) {
}
diff --git a/src/watchGuard/watchGuard.ts b/src/watchGuard/watchGuard.ts
index 3835540d9c990..b66338f42eb0a 100644
--- a/src/watchGuard/watchGuard.ts
+++ b/src/watchGuard/watchGuard.ts
@@ -1,10 +1,11 @@
///
+import * as fs from "fs";
+
if (process.argv.length < 3) {
process.exit(1);
}
const directoryName = process.argv[2];
-const fs: { watch(directoryName: string, options: any, callback: () => {}): any } = require("fs");
// main reason why we need separate process to check if it is safe to watch some path
// is to guard against crashes that cannot be intercepted with protected blocks and
// code in tsserver already can handle normal cases, like non-existing folders.