繁体   English   中英

在 TypeScript (TS-Node) 中运行 glob 命令

[英]Run glob command in TypeScript (TS-Node)

几个月前,我问过如何将 glob 输入到 Node 模式中。 我想在RITEway中运行测试,解决方案是使用riteway而不是node运行命令。

"test": "NODE_ENV=test riteway -r @babel/register 'src/**/*.test.js'",

现在我将项目转换为 TypeScript。 运行上面的命令(将.js更改为.ts之后),会引发以下错误:

$ NODE_ENV=test riteway -r @babel/register 'src/tests/**/*.test.ts' | tap-nirvana
/Users/user/my-proj/src/tests/fn.test.ts:1
import { describe } from 'riteway';
^^^^^^

SyntaxError: Cannot use import statement outside a module
    at wrapSafe (internal/modules/cjs/loader.js:979:16)
    at Module._compile (internal/modules/cjs/loader.js:1027:27)
    at Module._extensions..js (internal/modules/cjs/loader.js:1092:10)
    at Object.newLoader [as .js] (/Users/user/my-proj/node_modules/pirates/lib/index.js:104:7)
    at Module.load (internal/modules/cjs/loader.js:928:32)
    at Function.Module._load (internal/modules/cjs/loader.js:769:14)
    at Module.require (internal/modules/cjs/loader.js:952:19)
    at require (internal/modules/cjs/helpers.js:88:18)
    at /Users/user/my-proj/node_modules/riteway/bin/riteway:54:5
    at Array.forEach (<anonymous>)

谷歌搜索后,我想我必须使用ts-node ,但该命令与运行node有相同的问题。

yarn run v1.22.10
$ NODE_ENV=test ts-node -r @babel/register 'src/tests/**/*.test.ts' | tap-nirvana
Error: Cannot find module '/Users/user/my-project/src/tests/**/*.test.ts'

如何将命令提供给 RITEway,但使其与 TypeScript 一起使用?

{
  "compilerOptions": {
    "allowJs": true,
    "baseUrl": "./src",
    "esModuleInterop": true,
    "forceConsistentCasingInFileNames": true,
    "isolatedModules": true,
    "jsx": "preserve",
    "lib": ["dom", "dom.iterable", "esnext"],
    "module": "esnext",
    "moduleResolution": "node",
    "noEmit": true,
    "resolveJsonModule": true,
    "skipLibCheck": true,
    "strict": true,
    "target": "es5"
  },
  "exclude": ["node_modules"],
  "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx"]
}

您可以通过在riteway命令中注册ts-node/register/transpile-only来运行已编译的 typescript:

"test": "NODE_ENV=test  riteway -r ts-node/register/transpile-only 'src/**/*.test.ts'",

还要确保tsconfig中的module选项设置为commonjs

{
    "compilerOptions": {
        "allowJs": true,
        "baseUrl": "./src",
        "esModuleInterop": true,
        "forceConsistentCasingInFileNames": true,
        "isolatedModules": true,
        "jsx": "preserve",
        "lib": [
            "dom",
            "dom.iterable",
            "esnext"
        ],
        "module": "commonjs",
        "moduleResolution": "node",
        "noEmit": true,
        "resolveJsonModule": true,
        "skipLibCheck": true,
        "strict": true,
        "target": "es6"
    },
    "exclude": [
        "node_modules"
    ],
    "include": [
        "next-env.d.ts",
        "**/*.ts",
        "**/*.tsx"
    ]
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM