From 6ada22d8900d893cfc7af9c8fa1856b0317c3f00 Mon Sep 17 00:00:00 2001 From: HBobertz Date: Tue, 12 Nov 2024 00:00:35 -0500 Subject: [PATCH 1/8] remove downlevel-dts --- .projen/deps.json | 4 - .projenrc.ts | 1 - package.json | 1 - src/ambient/downlevel-dts.d.ts | 19 --- src/compiler.ts | 12 +- src/downlevel-dts.ts | 221 --------------------------------- test/compiler.test.ts | 3 +- test/downlevel.test.ts | 215 -------------------------------- yarn.lock | 6 +- 9 files changed, 5 insertions(+), 477 deletions(-) delete mode 100644 src/ambient/downlevel-dts.d.ts delete mode 100644 src/downlevel-dts.ts delete mode 100644 test/downlevel.test.ts diff --git a/.projen/deps.json b/.projen/deps.json index 5ed6debb..b0159208 100644 --- a/.projen/deps.json +++ b/.projen/deps.json @@ -156,10 +156,6 @@ "version": "^4", "type": "runtime" }, - { - "name": "downlevel-dts", - "type": "runtime" - }, { "name": "fast-deep-equal", "type": "runtime" diff --git a/.projenrc.ts b/.projenrc.ts index 6925a36f..93792e00 100644 --- a/.projenrc.ts +++ b/.projenrc.ts @@ -216,7 +216,6 @@ project.addDeps( '@jsii/spec', 'case', 'chalk@^4', - 'downlevel-dts', 'fast-deep-equal', 'log4js', 'semver', diff --git a/package.json b/package.json index d19af111..7a519474 100644 --- a/package.json +++ b/package.json @@ -74,7 +74,6 @@ "@jsii/spec": "^1.104.0", "case": "^1.6.3", "chalk": "^4", - "downlevel-dts": "^0.11.0", "fast-deep-equal": "^3.1.3", "log4js": "^6.9.1", "semver": "^7.6.3", diff --git a/src/ambient/downlevel-dts.d.ts b/src/ambient/downlevel-dts.d.ts deleted file mode 100644 index db3c9eed..00000000 --- a/src/ambient/downlevel-dts.d.ts +++ /dev/null @@ -1,19 +0,0 @@ -/** Hand-written declaration for the downlevel-dts module */ -declare module 'downlevel-dts' { - /** - * Rewrite .d.ts files created by any version of TypeScript so that they work - * with TypeScript 3.4 or later. It does this by converting code with new - * features into code that uses equivalent old features. - * - * @param src the directory containing the original .d.ts files - * @param target the directory in which to place re-written files - * @param targetVersion the target TypeScript version compatibility - * - * @note The "real" signature would allow semver.SemVer instances to be - * provided as `targetVersion`, but some code-path involves an - * `instanceof` test which will fail if somehow `downlevel-dts` is - * provided with its own install of the `semver` dependency, which we - * cannot control, so we disallow using `semver.SemVer` instances here. - */ - export function main(src: string, target: string, targetVersion: string): void; -} diff --git a/src/compiler.ts b/src/compiler.ts index 9e592ecc..357c9079 100644 --- a/src/compiler.ts +++ b/src/compiler.ts @@ -6,9 +6,7 @@ import * as ts from 'typescript'; import { Assembler } from './assembler'; import { findDependencyDirectory } from './common/find-utils'; -import { emitDownleveledDeclarations, TYPES_COMPAT } from './downlevel-dts'; import { Emitter } from './emitter'; -import { normalizeConfigPath } from './helpers'; import { JsiiDiagnostic } from './jsii-diagnostic'; import { ProjectInfo } from './project-info'; import { WARNINGSCODE_FILE_NAME } from './transforms/deprecation-warnings'; @@ -21,6 +19,7 @@ import * as utils from './utils'; const LOG = log4js.getLogger('jsii/compiler'); export const DIAGNOSTICS = 'diagnostics'; export const JSII_DIAGNOSTICS_CODE = 9999; +export const TYPES_COMPAT = '.types-compat'; export interface CompilerOptions { /** The information about the project to be built */ @@ -314,15 +313,6 @@ export class Compiler implements Emitter { LOG.error('Compilation errors prevented the JSII assembly from being created'); } - if (!hasErrors) { - emitDownleveledDeclarations( - this.projectRoot, - this.options.projectInfo.packageJson, - // outDir might be absolute. Need to normalize it. - normalizeConfigPath(this.projectRoot, this.tsconfig.compilerOptions.outDir), - ); - } - // Some extra validation on the config. // Make sure that { "./.warnings.jsii.js": "./.warnings.jsii.js" } is in the set of // exports, if they are specified. diff --git a/src/downlevel-dts.ts b/src/downlevel-dts.ts deleted file mode 100644 index ef020b00..00000000 --- a/src/downlevel-dts.ts +++ /dev/null @@ -1,221 +0,0 @@ -import { - copyFileSync, - existsSync, - mkdirSync, - mkdtempSync, - readdirSync, - readFileSync, - rmSync, - statSync, - writeFileSync, -} from 'node:fs'; -import { tmpdir } from 'node:os'; -import { basename, dirname, join, relative } from 'node:path'; -import { main as downlevel } from 'downlevel-dts'; -import * as log4js from 'log4js'; -import { SemVer } from 'semver'; -import * as ts from 'typescript'; -import type { PackageJson } from './project-info'; -import type { Mutable } from './utils'; - -export const TYPES_COMPAT = '.types-compat'; - -const LOG = log4js.getLogger('jsii/compiler'); - -const TS_VERSION = new SemVer(`${ts.versionMajorMinor}.0`); - -/** - * Declares what versions of the TypeScript language will be supported by the - * declarations files (and `typesVersions` entries) produced by this compiler - * release. - * - * This should contain only `major.minor` specifiers, similar to the value of - * the `ts.versionMajorMinor` property, and must be sorted in ascending version - * order, as this dictates the order of entries in the `typesVersions` redirects - * which has a direct impact on resolution (first match wins), and we don't want - * to have to perform a sort pass on this list. - */ -const DOWNLEVEL_BREAKPOINTS: readonly SemVer[] = ['3.9'].map((ver) => new SemVer(`${ver}.0`)); - -/** - * Produces down-leveled declaration files to ensure compatibility with previous - * compiler releases (matching TypeScript's `major.minor` versioning scheme). - * This is necessary in order to ensure a package change compiler release lines - * does not force all it's consumers to do the same (and vice-versa). - * - * @returns the `typesVersions` object that should be recorded in `package.json` - */ -export function emitDownleveledDeclarations(projectRoot: string, packageJson: PackageJson, outDir?: string) { - const compatRoot = join(projectRoot, ...(outDir != null ? [outDir] : []), TYPES_COMPAT); - rmSync(compatRoot, { force: true, recursive: true }); - - const rewrites = new Set<`${number}.${number}`>(); - - for (const breakpoint of DOWNLEVEL_BREAKPOINTS) { - if (TS_VERSION.compare(breakpoint) <= 0) { - // This TypeScript release is older or same as the breakpoint, so no need - // for down-leveling here. - continue; - } - - const rewriteSet = new Map(); - let needed = false; - - // We'll emit down-leveled declarations in a temporary directory... - const workdir = mkdtempSync(join(tmpdir(), `downlevel-dts-${breakpoint}-${basename(projectRoot)}-`)); - try { - downlevel(projectRoot, workdir, breakpoint.version); - const projectOutDir = outDir != null ? join(projectRoot, outDir) : projectRoot; - const workOutDir = outDir != null ? join(workdir, outDir) : workdir; - for (const dts of walkDirectory(workOutDir)) { - const original = readFileSync(join(projectOutDir, dts), 'utf-8'); - const downleveledPath = join(workOutDir, dts); - const downleveled = readFileSync(downleveledPath, 'utf-8'); - needed ||= !semanticallyEqualDeclarations(original, downleveled); - rewriteSet.set(dts, downleveledPath); - } - - // If none of the declarations files changed during the down-level, then - // we don't need to actually write it out & cause a redirect. This would - // be wasteful. Most codebases won't incur any rewrite at all, since the - // declarations files only reference "visible" members, and `jsii` - // actually does not allow most of the unsupported syntaxes to be used - // anyway. - if (needed) { - rewrites.add(`${breakpoint.major}.${breakpoint.minor}`); - - const versionSuffix = `ts${breakpoint.major}.${breakpoint.minor}`; - const compatDir = join(compatRoot, versionSuffix); - if (!existsSync(compatDir)) { - mkdirSync(compatDir, { recursive: true }); - try { - // Write an empty .npmignore file so that npm pack doesn't use the .gitignore file... - writeFileSync(join(compatRoot, '.npmignore'), '\n', 'utf-8'); - // Make sure all of this is gitignored, out of courtesy... - writeFileSync(join(compatRoot, '.gitignore'), '*\n', 'utf-8'); - } catch { - // Ignore any error here... This is inconsequential. - } - } - - for (const [dts, downleveledPath] of rewriteSet) { - const rewritten = join(compatDir, dts); - // Make sure the parent directory exists (dts might be nested) - mkdirSync(dirname(rewritten), { recursive: true }); - // Write the re-written declarations file there... - copyFileSync(downleveledPath, rewritten); - } - } - } catch (error) { - LOG.error(error); - } finally { - // Clean up after ourselves... - rmSync(workdir, { force: true, recursive: true }); - } - } - - let typesVersions: Mutable; - - for (const version of rewrites) { - // Register the type redirect in the typesVersions configuration - typesVersions ??= {}; - const from = [...(outDir != null ? [outDir] : []), '*'].join('/'); - const to = [...(outDir != null ? [outDir] : []), TYPES_COMPAT, `ts${version}`, '*'].join('/'); - // We put 2 candidate redirects (first match wins), so that it works for nested imports, too (see: https://github.com/microsoft/TypeScript/issues/43133) - typesVersions[`<=${version}`] = { [from]: [to, `${to}/index.d.ts`] }; - } - - // Compare JSON stringifications, as the order of keys is important here... - if (JSON.stringify(packageJson.typesVersions) === JSON.stringify(typesVersions)) { - // The existing configuration matches the new one. We're done here. - return; - } - - LOG.info('The required `typesVersions` configuration has changed. Updating "package.json" accordingly...'); - - // Prepare the new contents of `PackageJson`. - const newPackageJson = Object.entries(packageJson).reduce((obj, [key, value]) => { - // NB: "as any" below are required becuase we must ignore `readonly` attributes from the source. - if (key === 'typesVersions') { - if (typesVersions != null) { - obj[key] = typesVersions as any; - } - } else { - obj[key] = value as any; - // If there isn't currently a `typesVersions` entry, but there is a `types` entry, - // we'll insert `typesVersions` right after `types`. - if (key === 'types' && typesVersions != null && !('typesVersions' in packageJson)) { - obj.typesVersions = typesVersions as any; - } - } - return obj; - }, {} as Mutable); - // If there was neither `types` nor `typesVersions` in the original `package.json`, we'll - // add `typesVersions` at the end of it. - if (!('typesVersions' in newPackageJson)) { - newPackageJson.typesVersions = typesVersions as any; - } - - const packageJsonFile = join(projectRoot, 'package.json'); - - // We try "hard" to preserve the existing indent in the `package.json` file when updating it. - const [, indent] = readFileSync(packageJsonFile, 'utf-8').match(/^(\s*)"/m) ?? [null, 2]; - - writeFileSync(packageJsonFile, `${JSON.stringify(newPackageJson, undefined, indent)}\n`, 'utf-8'); -} - -/** - * Compares the contents of two declaration files semantically. - * - * @param left the first string. - * @param right the second string. - * - * @returns `true` if `left` and `right` contain the same declarations. - */ -function semanticallyEqualDeclarations(left: string, right: string): boolean { - // We normalize declarations largely by parsing & re-printing them. - const normalizeDeclarations = (code: string): string => { - const sourceFile = ts.createSourceFile('index.d.ts', code, ts.ScriptTarget.Latest, false, ts.ScriptKind.TS); - const printer = ts.createPrinter({ - newLine: ts.NewLineKind.LineFeed, - noEmitHelpers: true, - omitTrailingSemicolon: false, - removeComments: true, - }); - let normalized = printer.printFile(sourceFile); - - // TypeScript may emit duplicated reference declarations... which are absent from Downlevel-DTS' output... - // https://github.com/microsoft/TypeScript/issues/48143 - const REFERENCES_TYPES_NODE = '/// '; - while (normalized.startsWith(`${REFERENCES_TYPES_NODE}\n${REFERENCES_TYPES_NODE}`)) { - normalized = normalized.slice(REFERENCES_TYPES_NODE.length + 1); - } - - return normalized; - }; - - left = normalizeDeclarations(left); - right = normalizeDeclarations(right); - - return left === right; -} - -/** - * Recursively traverse the provided directory and yield the relative (to the - * specified `root`) paths of all the `.d.ts` files found there. - * - * @param dir the directory to be walked. - * @param root the root to which paths should be relative. - */ -function* walkDirectory(dir: string, root: string = dir): Generator { - for (const file of readdirSync(dir)) { - const filePath = join(dir, file); - if (statSync(filePath).isDirectory()) { - // This is a directory, recurse down... - yield* walkDirectory(filePath, root); - } else if (file.toLowerCase().endsWith('.d.ts')) { - // This is a declaration file, yield it... - yield relative(root, filePath); - } - } -} diff --git a/test/compiler.test.ts b/test/compiler.test.ts index 26036491..96d001a6 100644 --- a/test/compiler.test.ts +++ b/test/compiler.test.ts @@ -3,8 +3,7 @@ import { tmpdir } from 'node:os'; import { dirname, join } from 'node:path'; import { loadAssemblyFromPath, SPEC_FILE_NAME, SPEC_FILE_NAME_COMPRESSED } from '@jsii/spec'; import { compile, Lock } from './fixtures'; -import { Compiler } from '../src/compiler'; -import { TYPES_COMPAT } from '../src/downlevel-dts'; +import { Compiler, TYPES_COMPAT } from '../src/compiler'; import { ProjectInfo } from '../src/project-info'; import { TypeScriptConfigValidationRuleSet } from '../src/tsconfig'; import { TypeScriptConfigValidator } from '../src/tsconfig/tsconfig-validator'; diff --git a/test/downlevel.test.ts b/test/downlevel.test.ts deleted file mode 100644 index 81e0c373..00000000 --- a/test/downlevel.test.ts +++ /dev/null @@ -1,215 +0,0 @@ -import { mkdtempSync, writeFileSync, readFileSync, mkdirSync } from 'node:fs'; -import { tmpdir } from 'node:os'; -import { join } from 'node:path'; -import { Compiler } from '../src/compiler'; -import { TYPES_COMPAT } from '../src/downlevel-dts'; -import { PackageJson, ProjectInfo } from '../src/project-info'; - -describe('Compiler', () => { - describe('generated tsconfig', () => { - test('will downlevel code', () => { - // GIVEN - const sourceDir = mkdtempSync(join(tmpdir(), 'jsii-compiler-generated-')); - _writeDownlevelableCode(sourceDir); - - // WHEN - const compiler = new Compiler({ - projectInfo: { - ..._makeProjectInfo(sourceDir, 'index.d.ts'), - }, - }); - const result = compiler.emit(); - - // THEN code compiles - expect(result.diagnostics).toHaveLength(0); - expect(result.emitSkipped).toBe(false); - // THEN code is downleveled - const downleveled = readFileSync(join(sourceDir, '.types-compat/ts3.9/index.d.ts'), 'utf-8'); - expect(downleveled).toMatchInlineSnapshot(` - "declare class MarkerA { - } - export type { MarkerA }; - " - `); - // THEN typeVersions are written - const packageJson = readPackageJson(sourceDir); - expect(packageJson.typesVersions).toMatchObject({ - '<=3.9': { - '*': ['.types-compat/ts3.9/*', '.types-compat/ts3.9/*/index.d.ts'], - }, - }); - // THEN - const tsconfig = JSON.parse(readFileSync(join(sourceDir, 'tsconfig.json'), 'utf-8')); - expect(tsconfig.exclude).toMatchInlineSnapshot(` - [ - "node_modules", - ".types-compat", - ] - `); - }); - - test('will downlevel code with outdir', () => { - // GIVEN - const outDir = 'jsii-outdir'; - const srcDir = 'jsii-srcdir'; - const projectDir = mkdtempSync(join(tmpdir(), 'jsii-compiler-generated-')); - mkdirSync(join(projectDir, srcDir), { recursive: true }); - _writeDownlevelableCode(projectDir, srcDir); - - // WHEN - const compiler = new Compiler({ - projectInfo: { - ..._makeProjectInfo(projectDir, join(outDir, 'index.d.ts')), - tsc: { - outDir, - rootDir: srcDir, - }, - }, - }); - const result = compiler.emit(); - - // THEN code compiles - expect(result.diagnostics).toHaveLength(0); - expect(result.emitSkipped).toBe(false); - // THEN code is downleveled - const downleveled = readFileSync(join(projectDir, outDir, '.types-compat/ts3.9/index.d.ts'), 'utf-8'); - expect(downleveled).toMatchInlineSnapshot(` - "declare class MarkerA { - } - export type { MarkerA }; - " - `); - // THEN typeVersions are written - const packageJson = readPackageJson(projectDir); - expect(packageJson.typesVersions).toMatchObject({ - '<=3.9': { - 'jsii-outdir/*': ['jsii-outdir/.types-compat/ts3.9/*', 'jsii-outdir/.types-compat/ts3.9/*/index.d.ts'], - }, - }); - // THEN - const tsconfig = JSON.parse(readFileSync(join(projectDir, 'tsconfig.json'), 'utf-8')); - expect(tsconfig.exclude).toMatchInlineSnapshot(` - [ - "node_modules", - "jsii-outdir/.types-compat", - ] - `); - }); - }); - - describe('user-provided tsconfig', () => { - test('will downlevel code with outdir', () => { - // GIVEN - const outDir = 'jsii-outdir'; - const srcDir = 'jsii-srcdir'; - const projectDir = mkdtempSync(join(tmpdir(), 'jsii-compiler-user-tsconfig-')); - mkdirSync(join(projectDir, srcDir), { recursive: true }); - const tsconfigPath = 'tsconfig.dev.json'; - writeFileSync( - join(projectDir, tsconfigPath), - JSON.stringify( - tsconfigForNode18Strict({ - outDir, - rootDir: srcDir, - }), - null, - 2, - ), - ); - _writeDownlevelableCode(projectDir, srcDir); - - // WHEN - const compiler = new Compiler({ - projectInfo: _makeProjectInfo(projectDir, join(outDir, 'index.d.ts')), - typeScriptConfig: tsconfigPath, - }); - const result = compiler.emit(); - - // THEN code compiles - expect(result.diagnostics).toHaveLength(0); - expect(result.emitSkipped).toBe(false); - // THEN code is downleveled - const downleveled = readFileSync(join(projectDir, outDir, '.types-compat/ts3.9/index.d.ts'), 'utf-8'); - expect(downleveled).toMatchInlineSnapshot(` - "declare class MarkerA { - } - export type { MarkerA }; - " - `); - // THEN typeVersions are written - const packageJson = readPackageJson(projectDir); - expect(packageJson.typesVersions).toMatchObject({ - '<=3.9': { - 'jsii-outdir/*': ['jsii-outdir/.types-compat/ts3.9/*', 'jsii-outdir/.types-compat/ts3.9/*/index.d.ts'], - }, - }); - }); - }); -}); - -function readPackageJson(dir: string): PackageJson { - return JSON.parse(readFileSync(join(dir, 'package.json'), 'utf-8')); -} - -function _writeDownlevelableCode(projectDir: string, codeSubDir?: string) { - // Files in the project dir - writeFileSync(join(projectDir, 'README.md'), '# Test Package'); - writeFileSync(join(projectDir, 'package.json'), JSON.stringify({}, null, 2)); - - // Files in the code dir, e.g. `src` - const codeDir = codeSubDir ? join(projectDir, codeSubDir) : projectDir; - // See https://www.npmjs.com/package/downlevel-dts#type-modifiers-on-importexport-names-45 - writeFileSync(join(codeDir, 'index.ts'), 'class MarkerA {} export { type MarkerA }'); -} - -function _makeProjectInfo(sourceDir: string, types: string): ProjectInfo { - return { - projectRoot: sourceDir, - description: 'test', - homepage: 'https://github.com/aws/jsii-compiler', - packageJson: {}, - types, - main: types.replace(/(?:\.d)?\.ts(x?)/, '.js$1'), - name: 'jsii', // That's what package.json would tell if we look up... - version: '0.0.1', - jsiiVersionFormat: 'short', - license: 'Apache-2.0', - author: { name: 'John Doe', roles: ['author'] }, - repository: { type: 'git', url: 'https://github.com/aws/jsii.git' }, - dependencies: {}, - peerDependencies: {}, - dependencyClosure: [], - bundleDependencies: {}, - targets: {}, - excludeTypescript: [], - tsc: { - // NOTE: these are the default values jsii uses when none are provided in package.json. - inlineSourceMap: true, - inlineSources: true, - }, - }; -} - -/** - * An example of a user-provided config, based on the popular tsconfig/bases project & adjusted for the strict rule set - * @see https://github.com/tsconfig/bases/blob/main/bases/node18.json - */ -function tsconfigForNode18Strict(compilerOptions: any = {}) { - return { - compilerOptions: { - lib: ['es2022'], - module: 'node16', - target: 'es2022', - - strict: true, - esModuleInterop: true, - skipLibCheck: true, - noEmitOnError: true, - moduleResolution: 'node16', - declaration: true, - ...compilerOptions, - }, - exclude: ['node_modules', TYPES_COMPAT], - include: [join('**', '*.ts')], - }; -} diff --git a/yarn.lock b/yarn.lock index f77ada50..8553b22f 100644 --- a/yarn.lock +++ b/yarn.lock @@ -6439,9 +6439,9 @@ typedarray-to-buffer@^3.1.5: is-typedarray "^1.0.0" typescript@next: - version "5.8.0-dev.20241110" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.8.0-dev.20241110.tgz#0bf464a4d3389b3fe8bf8afe30769ca45ae7105b" - integrity sha512-0OdrDNPQVyHr/LRSAFbGnuI1a+J72vMFrAsEN2ge8MhW9eihGcqodQrkllBqBLt7dqFUexbK2qOxFun1SUFtQA== + version "5.8.0-dev.20241111" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.8.0-dev.20241111.tgz#8a481638472882e0c0bb6faec641a71b1858c76c" + integrity sha512-deGbPJipGG/DiJ4nR0NhFuccD2XD6xfUAQCvqMLWxVsM4p9zmhKNMWotkMQEm/l9HjXhnVr0dFJ8u4B9y3y+ZA== typescript@~3.9.10: version "3.9.10" From 1bc5dcdfdbf5c70fbed1fbff98e8a470e7fa8974 Mon Sep 17 00:00:00 2001 From: HBobertz Date: Tue, 12 Nov 2024 13:47:21 -0500 Subject: [PATCH 2/8] fix jsii-calc-base --- fixtures/@scope/jsii-calc-base/lib/index.ts | 2 +- fixtures/@scope/jsii-calc-base/package.json | 8 -- fixtures/jsii-calc/package.json | 8 -- test/__snapshots__/integration.test.ts.snap | 109 -------------------- test/integration.test.ts | 49 +-------- yarn.lock | 18 +--- 6 files changed, 5 insertions(+), 189 deletions(-) diff --git a/fixtures/@scope/jsii-calc-base/lib/index.ts b/fixtures/@scope/jsii-calc-base/lib/index.ts index 8e841bd5..737e7196 100644 --- a/fixtures/@scope/jsii-calc-base/lib/index.ts +++ b/fixtures/@scope/jsii-calc-base/lib/index.ts @@ -36,4 +36,4 @@ export class StaticConsumer { } } -export * as deep from './deep'; +export * as deep from './deep'; \ No newline at end of file diff --git a/fixtures/@scope/jsii-calc-base/package.json b/fixtures/@scope/jsii-calc-base/package.json index 9e71f34b..ba23c1c8 100644 --- a/fixtures/@scope/jsii-calc-base/package.json +++ b/fixtures/@scope/jsii-calc-base/package.json @@ -23,14 +23,6 @@ }, "main": "lib/index.js", "types": "lib/index.d.ts", - "typesVersions": { - "<=3.9": { - "*": [ - ".types-compat/ts3.9/*", - ".types-compat/ts3.9/*/index.d.ts" - ] - } - }, "exports": { ".": { "types": "./lib/index.d.ts", diff --git a/fixtures/jsii-calc/package.json b/fixtures/jsii-calc/package.json index b2885943..9bfbd740 100644 --- a/fixtures/jsii-calc/package.json +++ b/fixtures/jsii-calc/package.json @@ -32,14 +32,6 @@ }, "main": "lib/index.js", "types": "lib/index.d.ts", - "typesVersions": { - "<=3.9": { - "*": [ - ".types-compat/ts3.9/*", - ".types-compat/ts3.9/*/index.d.ts" - ] - } - }, "dependencies": { "@fixtures/jsii-calc-bundled": "file:../@fixtures/jsii-calc-bundled", "@scope/jsii-calc-base": "^0.0.0", diff --git a/test/__snapshots__/integration.test.ts.snap b/test/__snapshots__/integration.test.ts.snap index ec117e20..87be9bde 100644 --- a/test/__snapshots__/integration.test.ts.snap +++ b/test/__snapshots__/integration.test.ts.snap @@ -20399,112 +20399,3 @@ library, regardless of whether they were explicitly referenced or not.", "version": "3.20.120", } `; - -exports[`v1 compatibility check: test output assembly 1`] = ` -{ - "author": { - "name": "John Doe", - "roles": [ - "author", - ], - }, - "dependencies": { - "@scope/jsii-calc-base": "*", - }, - "dependencyClosure": { - "@scope/jsii-calc-base": { - "submodules": { - "@scope/jsii-calc-base.deep": {}, - }, - "targets": { - "dotnet": { - "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/main/logo/default-256-dark.png", - "namespace": "Amazon.JSII.Tests.CalculatorNamespace.BaseNamespace", - "packageId": "Amazon.JSII.Tests.CalculatorPackageId.BasePackageId", - }, - "go": { - "moduleName": "github.com/aws/jsii/jsii-calc/go", - "packageName": "jcb", - }, - "java": { - "maven": { - "artifactId": "calculator-base", - "groupId": "software.amazon.jsii.tests", - }, - "package": "software.amazon.jsii.tests.calculator.base", - }, - "js": { - "npm": "@scope/jsii-calc-base", - }, - "python": { - "distName": "scope.jsii-calc-base", - "module": "scope.jsii_calc_base", - }, - }, - }, - "@scope/jsii-calc-base-of-base": { - "targets": { - "dotnet": { - "namespace": "Amazon.JSII.Tests.CalculatorNamespace.BaseOfBaseNamespace", - "packageId": "Amazon.JSII.Tests.CalculatorPackageId.BaseOfBasePackageId", - }, - "go": { - "moduleName": "github.com/aws/jsii/jsii-calc/go", - }, - "java": { - "maven": { - "artifactId": "calculator-base-of-base", - "groupId": "software.amazon.jsii.tests", - }, - "package": "software.amazon.jsii.tests.calculator.baseofbase", - }, - "js": { - "npm": "@scope/jsii-calc-base-of-base", - }, - "python": { - "distName": "scope.jsii-calc-base-of-base", - "module": "scope.jsii_calc_base_of_base", - }, - }, - }, - }, - "description": "testpkg", - "fingerprint": Any, - "homepage": "https://github.com/aws/jsii.git", - "jsiiVersion": Any, - "license": "Apache-2.0", - "metadata": { - "jsii": { - "pacmak": { - "hasDefaultInterfaces": true, - }, - }, - }, - "name": "testpkg", - "repository": { - "type": "git", - "url": "https://github.com/aws/jsii.git", - }, - "schema": "jsii/0.10.0", - "targets": { - "js": { - "npm": "testpkg", - }, - }, - "types": { - "testpkg.SomeClass": { - "assembly": "testpkg", - "base": "@scope/jsii-calc-base.deep.BarrelImportClass", - "fqn": "testpkg.SomeClass", - "kind": "class", - "locationInModule": { - "filename": "index.ts", - "line": 4, - }, - "name": "SomeClass", - "symbolId": "index:SomeClass", - }, - }, - "version": "0.0.1", -} -`; diff --git a/test/integration.test.ts b/test/integration.test.ts index d32ad10b..f65f2a84 100644 --- a/test/integration.test.ts +++ b/test/integration.test.ts @@ -1,10 +1,9 @@ import { spawnSync } from 'node:child_process'; -import { mkdirSync, mkdtempSync, rmSync } from 'node:fs'; +import { mkdirSync, rmSync } from 'node:fs'; import { join } from 'node:path'; import { Assembly, loadAssemblyFromPath } from '@jsii/spec'; -import { compileJsiiForTest as compileJsiiV1 } from 'jsii-1.x'; -import { compile, FIXTURES_ROOT, Lock } from './fixtures'; +import { compile, Lock } from './fixtures'; let lock: Lock | undefined; @@ -52,50 +51,6 @@ test('integration test', () => { } }, 120_000); -test('v1 compatibility check', () => { - const compilationDirectory = mkdtempSync(join(FIXTURES_ROOT, '.jsii-v1.')); - try { - const result = compileJsiiV1( - [ - // Import the `jsii-calc` library... Which includes TypeScript 3.9 - // unsupported syntax, such as the `type` modifier on import elements, - // etc... - 'import * as calc from "jsii-calc";', - 'import * as deep from "@scope/jsii-calc-base/lib/deep";', - '', - // Export some class so the assembly isn't empty (not that it matters, - // really), but most use stuff from `calc` so it's not elided by the - // compiler. - 'export class SomeClass extends deep.BarrelImportClass {', - ' private constructor() {', - ' super();', - '', - ' const calculator = new calc.Calculator();', - ' calculator.add(42);', - ' calculator.mul(1337);', - ' calculator.expression;', - ' }', - '}', - ].join('\n'), - { - compilationDirectory, - packageJson: { - dependencies: { '@scope/jsii-calc-base': '*' }, - jsii: { - tsc: { - types: [], - }, - }, - }, - }, - ); - - expect(result.assembly).toMatchSnapshot(DEFAULT_MATCHER, 'test output assembly'); - } finally { - rmSync(compilationDirectory, { force: true, recursive: true }); - } -}); - const DEFAULT_MATCHER: Partial = { fingerprint: expect.any(String), jsiiVersion: expect.any(String), diff --git a/yarn.lock b/yarn.lock index 8553b22f..09b17da6 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2390,15 +2390,6 @@ dot-prop@^6.0.1: dependencies: is-obj "^2.0.0" -downlevel-dts@^0.11.0: - version "0.11.0" - resolved "https://registry.yarnpkg.com/downlevel-dts/-/downlevel-dts-0.11.0.tgz#514a2d723009c5845730c1db6c994484c596ed9c" - integrity sha512-vo835pntK7kzYStk7xUHDifiYJvXxVhUapt85uk2AI94gUUAQX9HNRtrcMHNSc3YHJUEHGbYIGsM99uIbgAtxw== - dependencies: - semver "^7.3.2" - shelljs "^0.8.3" - typescript next - eastasianwidth@^0.2.0: version "0.2.0" resolved "https://registry.yarnpkg.com/eastasianwidth/-/eastasianwidth-0.2.0.tgz#696ce2ec0aa0e6ea93a397ffcf24aa7840c827cb" @@ -5828,7 +5819,7 @@ semver@^6.3.0, semver@^6.3.1: resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.1.tgz#556d2ef8689146e46dcea4bfdd095f3434dffcb4" integrity sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA== -semver@^7.1.1, semver@^7.3.2, semver@^7.3.5, semver@^7.3.7, semver@^7.5.3, semver@^7.5.4, semver@^7.6.0, semver@^7.6.3: +semver@^7.1.1, semver@^7.3.5, semver@^7.3.7, semver@^7.5.3, semver@^7.5.4, semver@^7.6.0, semver@^7.6.3: version "7.6.3" resolved "https://registry.yarnpkg.com/semver/-/semver-7.6.3.tgz#980f7b5550bc175fb4dc09403085627f9eb33143" integrity sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A== @@ -5872,7 +5863,7 @@ shebang-regex@^3.0.0: resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== -shelljs@^0.8.3, shelljs@^0.8.5: +shelljs@^0.8.5: version "0.8.5" resolved "https://registry.yarnpkg.com/shelljs/-/shelljs-0.8.5.tgz#de055408d8361bed66c669d2f000538ced8ee20c" integrity sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow== @@ -6438,11 +6429,6 @@ typedarray-to-buffer@^3.1.5: dependencies: is-typedarray "^1.0.0" -typescript@next: - version "5.8.0-dev.20241111" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.8.0-dev.20241111.tgz#8a481638472882e0c0bb6faec641a71b1858c76c" - integrity sha512-deGbPJipGG/DiJ4nR0NhFuccD2XD6xfUAQCvqMLWxVsM4p9zmhKNMWotkMQEm/l9HjXhnVr0dFJ8u4B9y3y+ZA== - typescript@~3.9.10: version "3.9.10" resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.9.10.tgz#70f3910ac7a51ed6bef79da7800690b19bf778b8" From c8134ea9d293a2a88c73e04c159056597ed5afe1 Mon Sep 17 00:00:00 2001 From: github-actions Date: Tue, 12 Nov 2024 19:01:46 +0000 Subject: [PATCH 3/8] chore: self-mutation Signed-off-by: github-actions --- yarn.lock | 5 ----- 1 file changed, 5 deletions(-) diff --git a/yarn.lock b/yarn.lock index ca5f125d..93479542 100644 --- a/yarn.lock +++ b/yarn.lock @@ -6429,11 +6429,6 @@ typedarray-to-buffer@^3.1.5: dependencies: is-typedarray "^1.0.0" -typescript@next: - version "5.8.0-dev.20241111" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.8.0-dev.20241111.tgz#8a481638472882e0c0bb6faec641a71b1858c76c" - integrity sha512-deGbPJipGG/DiJ4nR0NhFuccD2XD6xfUAQCvqMLWxVsM4p9zmhKNMWotkMQEm/l9HjXhnVr0dFJ8u4B9y3y+ZA== - typescript@~3.9.10: version "3.9.10" resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.9.10.tgz#70f3910ac7a51ed6bef79da7800690b19bf778b8" From acf4ef22ffa636a21d0766566216d44ca27dd149 Mon Sep 17 00:00:00 2001 From: Hogan Bobertz Date: Wed, 13 Nov 2024 09:39:32 -0500 Subject: [PATCH 4/8] Update fixtures/@scope/jsii-calc-base/lib/index.ts Co-authored-by: Momo Kornher Signed-off-by: Hogan Bobertz --- fixtures/@scope/jsii-calc-base/lib/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/fixtures/@scope/jsii-calc-base/lib/index.ts b/fixtures/@scope/jsii-calc-base/lib/index.ts index 737e7196..8e841bd5 100644 --- a/fixtures/@scope/jsii-calc-base/lib/index.ts +++ b/fixtures/@scope/jsii-calc-base/lib/index.ts @@ -36,4 +36,4 @@ export class StaticConsumer { } } -export * as deep from './deep'; \ No newline at end of file +export * as deep from './deep'; From d8c8e65752748c769bf937b278f0ffff41974078 Mon Sep 17 00:00:00 2001 From: Hogan Bobertz Date: Wed, 13 Nov 2024 09:39:56 -0500 Subject: [PATCH 5/8] Update test/compiler.test.ts Co-authored-by: Momo Kornher Signed-off-by: Hogan Bobertz --- test/compiler.test.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/compiler.test.ts b/test/compiler.test.ts index 96d001a6..c1a8f61b 100644 --- a/test/compiler.test.ts +++ b/test/compiler.test.ts @@ -3,7 +3,7 @@ import { tmpdir } from 'node:os'; import { dirname, join } from 'node:path'; import { loadAssemblyFromPath, SPEC_FILE_NAME, SPEC_FILE_NAME_COMPRESSED } from '@jsii/spec'; import { compile, Lock } from './fixtures'; -import { Compiler, TYPES_COMPAT } from '../src/compiler'; +import { Compiler } from '../src/compiler'; import { ProjectInfo } from '../src/project-info'; import { TypeScriptConfigValidationRuleSet } from '../src/tsconfig'; import { TypeScriptConfigValidator } from '../src/tsconfig/tsconfig-validator'; From c4cf4b7def3459c1dceaf9eb211d3e322ce179b2 Mon Sep 17 00:00:00 2001 From: Hogan Bobertz Date: Wed, 13 Nov 2024 09:40:05 -0500 Subject: [PATCH 6/8] Update src/compiler.ts Co-authored-by: Momo Kornher Signed-off-by: Hogan Bobertz --- src/compiler.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/src/compiler.ts b/src/compiler.ts index 357c9079..d9d14d5c 100644 --- a/src/compiler.ts +++ b/src/compiler.ts @@ -19,7 +19,6 @@ import * as utils from './utils'; const LOG = log4js.getLogger('jsii/compiler'); export const DIAGNOSTICS = 'diagnostics'; export const JSII_DIAGNOSTICS_CODE = 9999; -export const TYPES_COMPAT = '.types-compat'; export interface CompilerOptions { /** The information about the project to be built */ From 1ef58fff6e3fdee23537bbd441ac2f53017d07ad Mon Sep 17 00:00:00 2001 From: HBobertz Date: Wed, 13 Nov 2024 09:50:03 -0500 Subject: [PATCH 7/8] fix typescompat --- src/compiler.ts | 4 ---- test/compiler.test.ts | 4 ++-- 2 files changed, 2 insertions(+), 6 deletions(-) diff --git a/src/compiler.ts b/src/compiler.ts index d9d14d5c..723dff69 100644 --- a/src/compiler.ts +++ b/src/compiler.ts @@ -354,9 +354,6 @@ export class Compiler implements Emitter { } const pi = this.options.projectInfo; - const configDir = path.dirname(this.configPath); - const absoluteTypesCompat = path.resolve(configDir, pi.tsc?.outDir ?? '.', TYPES_COMPAT); - const relativeTypesCompat = path.relative(configDir, absoluteTypesCompat); return { compilerOptions: { @@ -370,7 +367,6 @@ export class Compiler implements Emitter { include: [pi.tsc?.rootDir != null ? path.join(pi.tsc.rootDir, '**', '*.ts') : path.join('**', '*.ts')], exclude: [ 'node_modules', - relativeTypesCompat, ...(pi.excludeTypescript ?? []), ...(pi.tsc?.outDir != null && (pi.tsc?.rootDir == null || path.resolve(pi.tsc.outDir).startsWith(path.resolve(pi.tsc.rootDir) + path.sep)) diff --git a/test/compiler.test.ts b/test/compiler.test.ts index c1a8f61b..aeeb2507 100644 --- a/test/compiler.test.ts +++ b/test/compiler.test.ts @@ -452,7 +452,7 @@ function expectedTypeScriptConfig() { target: 'es2020', tsBuildInfoFile: 'tsconfig.tsbuildinfo', }, - exclude: ['node_modules', TYPES_COMPAT], + exclude: ['node_modules'], include: [join('**', '*.ts')], }; } @@ -475,7 +475,7 @@ function tsconfigForNode18Strict() { moduleResolution: 'node16', declaration: true, }, - exclude: ['node_modules', TYPES_COMPAT], + exclude: ['node_modules'], include: [join('**', '*.ts')], }; } From ab4af37a5799428fbf1c6518c6b795f8e184091b Mon Sep 17 00:00:00 2001 From: github-actions Date: Wed, 13 Nov 2024 14:54:23 +0000 Subject: [PATCH 8/8] chore: self-mutation Signed-off-by: github-actions --- yarn.lock | 5 ----- 1 file changed, 5 deletions(-) diff --git a/yarn.lock b/yarn.lock index 5eeb5072..60d184c7 100644 --- a/yarn.lock +++ b/yarn.lock @@ -6429,11 +6429,6 @@ typedarray-to-buffer@^3.1.5: dependencies: is-typedarray "^1.0.0" -typescript@next: - version "5.8.0-dev.20241112" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.8.0-dev.20241112.tgz#7852a824ebb53175239648f244a77fcffaaf469d" - integrity sha512-h5Ik9z9sIGe898ya+9bG+XBZQHzSYFY0Q1X9QmsDjcX2xf3jwNnWaUAE0NLVw0Lx+XBRBB2qf7GyfeqDNrzofQ== - typescript@~3.9.10: version "3.9.10" resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.9.10.tgz#70f3910ac7a51ed6bef79da7800690b19bf778b8"