-
Notifications
You must be signed in to change notification settings - Fork 72
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(bundle-source): Support TypeScript type erasure (#2627)
Closes: #2415 ## Description This change introduces support for TypeScript through type-erasure, using ts-blank-space, which converts type annotations to equivalent blank space. As is consistent with `node --experimental-strip-types`, this only applies to modules with the `.ts`, `.mts`, or `.cts` extensions in packages that are not under `node_modules`, to discourage publishing TypeScript as a source language to npm. ### Security Considerations The choice of `ts-blank-space` is intended to minimize runtime behavior difference between TypeScript and JavaScript, such that a reviewer or a debugger of the generated JavaScript aligns with the expected behavior and original text, to the extent that is possible. This should compose well with #2444. ### Scaling Considerations None. ### Documentation Considerations Contains README and NEWS. ### Testing Considerations Contains spot check tests for TypeScript in the endoScript and endoZipBase64 formats. We stand on much more rigorous testing of the underlying workspace-language-for-extension feature in Compartment Mapper #2625. ### Compatibility Considerations This does not break any prior usage. ### Upgrade Considerations None.
- Loading branch information
Showing
15 changed files
with
276 additions
and
44 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
export const fortune: string = 'outlook uncertain'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
// fortune.js does not exist, but fortune.ts does. | ||
export { fortune } from './fortune.js'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
/* eslint-disable @endo/restrict-comparison-operands */ | ||
|
||
export { fortune } from './fortune.ts'; | ||
|
||
if (((0).toFixed.apply < Number, String > 1) === true) { | ||
throw new Error('JavaScript interpreted as TypeScript'); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
export { fortune } from './fortune.ts'; | ||
|
||
if ((0).toFixed.apply<Number, String>(1) === false) { | ||
throw new Error('TypeScript interpreted as JavaScript'); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
/* eslint-disable @endo/restrict-comparison-operands */ | ||
|
||
export { meaning } from './meaning.js'; | ||
|
||
if (((0).toFixed.apply < Number, String > 1) === true) { | ||
throw new Error('JavaScript interpreted as TypeScript'); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
export { meaning } from './meaning.js'; | ||
|
||
if ((0).toFixed.apply<Number, String>(1) === false) { | ||
throw new Error('TypeScript interpreted as JavaScript'); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
// @ts-check | ||
import test from '@endo/ses-ava/prepare-endo.js'; | ||
|
||
import url from 'url'; | ||
import { decodeBase64 } from '@endo/base64'; | ||
import { ZipReader } from '@endo/zip'; | ||
import bundleSource from '../src/index.js'; | ||
|
||
test('no-transforms applies no transforms', async t => { | ||
const entryPath = url.fileURLToPath( | ||
new URL(`../demo/fortune.ts`, import.meta.url), | ||
); | ||
const { endoZipBase64 } = await bundleSource(entryPath, { | ||
format: 'endoZipBase64', | ||
noTransforms: true, | ||
}); | ||
const endoZipBytes = decodeBase64(endoZipBase64); | ||
const zipReader = new ZipReader(endoZipBytes); | ||
const compartmentMapBytes = zipReader.read('compartment-map.json'); | ||
const compartmentMapText = new TextDecoder().decode(compartmentMapBytes); | ||
const compartmentMap = JSON.parse(compartmentMapText); | ||
const { entry, compartments } = compartmentMap; | ||
const compartment = compartments[entry.compartment]; | ||
const module = compartment.modules[entry.module]; | ||
// Transformed from TypeScript: | ||
t.is(module.parser, 'mjs'); | ||
|
||
const moduleBytes = zipReader.read( | ||
`${compartment.location}/${module.location}`, | ||
); | ||
const moduleText = new TextDecoder().decode(moduleBytes); | ||
t.is( | ||
moduleText.trim(), | ||
`export const fortune = 'outlook uncertain';`, | ||
// Erased: : string | ||
); | ||
}); |
Oops, something went wrong.