mirror of
https://github.com/denoland/deno.git
synced 2025-01-18 11:53:59 -05:00
b402b75c1d
Fixes #6663
222 lines
5.7 KiB
TypeScript
222 lines
5.7 KiB
TypeScript
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
|
import {
|
|
assert,
|
|
assertEquals,
|
|
assertThrowsAsync,
|
|
} from "../../std/testing/asserts.ts";
|
|
|
|
Deno.test({
|
|
name: "Deno.compile() - sources provided",
|
|
async fn() {
|
|
const [diagnostics, actual] = await Deno.compile("/foo.ts", {
|
|
"/foo.ts": `import * as bar from "./bar.ts";\n\nconsole.log(bar);\n`,
|
|
"/bar.ts": `export const bar = "bar";\n`,
|
|
});
|
|
assert(diagnostics == null);
|
|
assert(actual);
|
|
const keys = Object.keys(actual).sort();
|
|
assert(keys[0].endsWith("/bar.ts.js"));
|
|
assert(keys[1].endsWith("/bar.ts.js.map"));
|
|
assert(keys[2].endsWith("/foo.ts.js"));
|
|
assert(keys[3].endsWith("/foo.ts.js.map"));
|
|
},
|
|
});
|
|
|
|
Deno.test({
|
|
name: "Deno.compile() - no sources provided",
|
|
async fn() {
|
|
const [diagnostics, actual] = await Deno.compile("./subdir/mod1.ts");
|
|
assert(diagnostics == null);
|
|
assert(actual);
|
|
const keys = Object.keys(actual).sort();
|
|
assertEquals(keys.length, 6);
|
|
assert(keys[0].endsWith("cli/tests/subdir/mod1.ts.js"));
|
|
assert(keys[1].endsWith("cli/tests/subdir/mod1.ts.js.map"));
|
|
},
|
|
});
|
|
|
|
Deno.test({
|
|
name: "Deno.compile() - compiler options effects emit",
|
|
async fn() {
|
|
const [diagnostics, actual] = await Deno.compile(
|
|
"/foo.ts",
|
|
{
|
|
"/foo.ts": `export const foo = "foo";`,
|
|
},
|
|
{
|
|
module: "amd",
|
|
sourceMap: false,
|
|
},
|
|
);
|
|
assert(diagnostics == null);
|
|
assert(actual);
|
|
const keys = Object.keys(actual);
|
|
assertEquals(keys.length, 1);
|
|
const key = keys[0];
|
|
assert(key.endsWith("/foo.ts.js"));
|
|
assert(actual[key].startsWith("define("));
|
|
},
|
|
});
|
|
|
|
Deno.test({
|
|
name: "Deno.compile() - pass lib in compiler options",
|
|
async fn() {
|
|
const [diagnostics, actual] = await Deno.compile(
|
|
"file:///foo.ts",
|
|
{
|
|
"file:///foo.ts": `console.log(document.getElementById("foo"));
|
|
console.log(Deno.args);`,
|
|
},
|
|
{
|
|
lib: ["dom", "es2018", "deno.ns"],
|
|
},
|
|
);
|
|
assert(diagnostics == null);
|
|
assert(actual);
|
|
assertEquals(
|
|
Object.keys(actual).sort(),
|
|
["file:///foo.ts.js", "file:///foo.ts.js.map"],
|
|
);
|
|
},
|
|
});
|
|
|
|
// TODO(@kitsonk) figure the "right way" to restore support for types
|
|
// Deno.test({
|
|
// name: "Deno.compile() - properly handles .d.ts files",
|
|
// async fn() {
|
|
// const [diagnostics, actual] = await Deno.compile(
|
|
// "/foo.ts",
|
|
// {
|
|
// "/foo.ts": `console.log(Foo.bar);`,
|
|
// "/foo_types.d.ts": `declare namespace Foo {
|
|
// const bar: string;
|
|
// }`,
|
|
// },
|
|
// {
|
|
// types: ["/foo_types.d.ts"],
|
|
// },
|
|
// );
|
|
// assert(diagnostics == null);
|
|
// assert(actual);
|
|
// assertEquals(
|
|
// Object.keys(actual).sort(),
|
|
// ["file:///foo.ts.js", "file:///file.ts.js.map"],
|
|
// );
|
|
// },
|
|
// });
|
|
|
|
Deno.test({
|
|
name: "Deno.transpileOnly()",
|
|
async fn() {
|
|
const actual = await Deno.transpileOnly({
|
|
"foo.ts": `export enum Foo { Foo, Bar, Baz };\n`,
|
|
});
|
|
assert(actual);
|
|
assertEquals(Object.keys(actual), ["foo.ts"]);
|
|
assert(actual["foo.ts"].source.startsWith("export var Foo;"));
|
|
assert(actual["foo.ts"].map);
|
|
},
|
|
});
|
|
|
|
Deno.test({
|
|
name: "Deno.transpileOnly() - config effects commit",
|
|
async fn() {
|
|
const actual = await Deno.transpileOnly(
|
|
{
|
|
"foo.ts": `/** This is JSDoc */\nexport enum Foo { Foo, Bar, Baz };\n`,
|
|
},
|
|
{
|
|
removeComments: true,
|
|
},
|
|
);
|
|
assert(actual);
|
|
assertEquals(Object.keys(actual), ["foo.ts"]);
|
|
assert(!actual["foo.ts"].source.includes("This is JSDoc"));
|
|
assert(actual["foo.ts"].map);
|
|
},
|
|
});
|
|
|
|
Deno.test({
|
|
name: "Deno.bundle() - sources passed",
|
|
async fn() {
|
|
const [diagnostics, actual] = await Deno.bundle("/foo.ts", {
|
|
"/foo.ts": `export * from "./bar.ts";\n`,
|
|
"/bar.ts": `export const bar = "bar";\n`,
|
|
});
|
|
assert(diagnostics == null);
|
|
assert(actual.includes(`const bar = "bar"`));
|
|
},
|
|
});
|
|
|
|
Deno.test({
|
|
name: "Deno.bundle() - no sources passed",
|
|
async fn() {
|
|
const [diagnostics, actual] = await Deno.bundle("./subdir/mod1.ts");
|
|
assert(diagnostics == null);
|
|
assert(actual.length);
|
|
},
|
|
});
|
|
|
|
Deno.test({
|
|
name: "Deno.bundle() - JS Modules included",
|
|
async fn() {
|
|
const [diagnostics, actual] = await Deno.bundle("/foo.js", {
|
|
"/foo.js": `export * from "./bar.js";\n`,
|
|
"/bar.js": `export const bar = "bar";\n`,
|
|
});
|
|
assert(diagnostics == null);
|
|
assert(actual.includes(`const bar = "bar"`));
|
|
},
|
|
});
|
|
|
|
Deno.test({
|
|
name: "runtime compiler APIs diagnostics",
|
|
async fn() {
|
|
const [diagnostics] = await Deno.compile("/foo.ts", {
|
|
"/foo.ts": `document.getElementById("foo");`,
|
|
});
|
|
assert(Array.isArray(diagnostics));
|
|
assert(diagnostics.length === 1);
|
|
},
|
|
});
|
|
|
|
// See https://github.com/denoland/deno/issues/6908
|
|
Deno.test({
|
|
name: "Deno.compile() - SWC diagnostics",
|
|
async fn() {
|
|
await assertThrowsAsync(async () => {
|
|
await Deno.compile("/main.js", {
|
|
"/main.js": `
|
|
export class Foo {
|
|
constructor() {
|
|
console.log("foo");
|
|
}
|
|
export get() {
|
|
console.log("bar");
|
|
}
|
|
}`,
|
|
});
|
|
});
|
|
},
|
|
});
|
|
|
|
Deno.test({
|
|
name: `Deno.compile() - Allows setting of "importsNotUsedAsValues"`,
|
|
async fn() {
|
|
const [diagnostics] = await Deno.compile("/a.ts", {
|
|
"/a.ts": `import { B } from "./b.ts";
|
|
const b: B = { b: "b" };
|
|
`,
|
|
"/b.ts": `export interface B {
|
|
b: string;
|
|
};
|
|
`,
|
|
}, {
|
|
importsNotUsedAsValues: "error",
|
|
});
|
|
assert(diagnostics);
|
|
assertEquals(diagnostics.length, 1);
|
|
assert(diagnostics[0].messageText);
|
|
assert(diagnostics[0].messageText.includes("This import is never used"));
|
|
},
|
|
});
|