diff options
| author | 2022-08-10 15:08:54 -0700 | |
|---|---|---|
| committer | 2022-08-10 15:08:54 -0700 | |
| commit | 2644b9d792e46fff9295f3e2d8df1995f2e88ca2 (patch) | |
| tree | 9819388dd6ee4bb47959ba270513978d67228ada /test/bun.js | |
| parent | 67cdf1c9b3aaeb823b513e85ca88dab6ce49897f (diff) | |
| download | bun-2644b9d792e46fff9295f3e2d8df1995f2e88ca2.tar.gz bun-2644b9d792e46fff9295f3e2d8df1995f2e88ca2.tar.zst bun-2644b9d792e46fff9295f3e2d8df1995f2e88ca2.zip | |
[TS] Fix bug with `import Foo = require("bar")`
Closes https://github.com/oven-sh/bun/issues/1045
Diffstat (limited to 'test/bun.js')
| -rw-r--r-- | test/bun.js/transpiler.test.js | 157 | 
1 files changed, 95 insertions, 62 deletions
| diff --git a/test/bun.js/transpiler.test.js b/test/bun.js/transpiler.test.js index f8da4c18c..51e1e669d 100644 --- a/test/bun.js/transpiler.test.js +++ b/test/bun.js/transpiler.test.js @@ -1,6 +1,101 @@  import { expect, it, describe } from "bun:test";  describe("Bun.Transpiler", () => { +  const transpiler = new Bun.Transpiler({ +    loader: "tsx", +    define: { +      "process.env.NODE_ENV": JSON.stringify("development"), +      user_undefined: "undefined", +    }, +    macro: { +      react: { +        bacon: `${import.meta.dir}/macro-check.js`, +      }, +    }, +    platform: "browser", +  }); + +  const ts = { +    parsed: (code, trim = true, autoExport = false) => { +      if (autoExport) { +        code = "export default (" + code + ")"; +      } + +      var out = transpiler.transformSync(code, "ts"); +      if (autoExport && out.startsWith("export default ")) { +        out = out.substring("export default ".length); +      } + +      if (trim) { +        out = out.trim(); + +        if (out.endsWith(";")) { +          out = out.substring(0, out.length - 1); +        } + +        return out.trim(); +      } + +      return out; +    }, + +    expectPrinted: (code, out) => { +      expect(ts.parsed(code, true, true)).toBe(out); +    }, + +    expectPrinted_: (code, out) => { +      expect(ts.parsed(code, !out.endsWith(";\n"), false)).toBe(out); +    }, + +    expectParseError: (code, message) => { +      try { +        ts.parsed(code, false, false); +      } catch (er) { +        var err = er; +        if (er instanceof AggregateError) { +          err = err.errors[0]; +        } + +        expect(er.message).toBe(message); + +        return; +      } + +      throw new Error("Expected parse error for code\n\t" + code); +    }, +  }; + +  describe("TypeScript", () => { +    it("import Foo = Baz.Bar", () => { +      ts.expectPrinted_( +        "import Foo = Baz.Bar;\nexport default Foo;", +        "const Foo = Baz.Bar;\nexport default Foo" +      ); +    }); + +    it("import Foo = require('bar')", () => { +      ts.expectPrinted_( +        "import React = require('react')", +        'const React = require("react")' +      ); +    }); + +    it("import type Foo = require('bar')", () => { +      ts.expectPrinted_("import type Foo = require('bar')", ""); +    }); + +    it("unused import = gets removed", () => { +      ts.expectPrinted_("import Foo = Baz.Bar;", ""); +    }); + +    it("export import Foo = Baz.Bar", () => { +      ts.expectPrinted_( +        "export import Foo = Baz.Bar;", +        "export const Foo = Baz.Bar" +      ); +    }); +  }); +    describe("exports.replace", () => {      const transpiler = new Bun.Transpiler({        exports: { @@ -111,19 +206,6 @@ describe("Bun.Transpiler", () => {      });    }); -  const transpiler = new Bun.Transpiler({ -    loader: "tsx", -    define: { -      "process.env.NODE_ENV": JSON.stringify("development"), -      user_undefined: "undefined", -    }, -    macro: { -      react: { -        bacon: `${import.meta.dir}/macro-check.js`, -      }, -    }, -    platform: "browser", -  });    const bunTranspiler = new Bun.Transpiler({      loader: "tsx",      define: { @@ -496,55 +578,6 @@ export var ComponentThatHasSpreadCausesDeopt = jsx(Hello, {      throw new Error("Expected parse error for code\n\t" + code);    }; -  const ts = { -    parsed: (code, trim = true, autoExport = false) => { -      if (autoExport) { -        code = "export default (" + code + ")"; -      } - -      var out = transpiler.transformSync(code, "ts"); -      if (autoExport && out.startsWith("export default ")) { -        out = out.substring("export default ".length); -      } - -      if (trim) { -        out = out.trim(); - -        if (out.endsWith(";")) { -          out = out.substring(0, out.length - 1); -        } - -        return out.trim(); -      } - -      return out; -    }, - -    expectPrinted: (code, out) => { -      expect(ts.parsed(code, true, true)).toBe(out); -    }, - -    expectPrinted_: (code, out) => { -      expect(ts.parsed(code, !out.endsWith(";\n"), false)).toBe(out); -    }, - -    expectParseError: (code, message) => { -      try { -        ts.parsed(code, false, false); -      } catch (er) { -        var err = er; -        if (er instanceof AggregateError) { -          err = err.errors[0]; -        } - -        expect(er.message).toBe(message); - -        return; -      } - -      throw new Error("Expected parse error for code\n\t" + code); -    }, -  };    describe("parser", () => {      it("arrays", () => { | 
