我正在尝试为我的基于typescript的项目编写一些自定义的ESLint规则。在我的项目中,我使用eslint/typescript进行线条处理。
我已经编写了一个自定义eslint插件来验证自定义规则。现在,我想为该自定义规则编写单元测试。我的测试文件如下所示:
/**
* @fileoverview This rule verifies that logic can only depend on other logic
* @author Dayem Siddiqui
*/
"use strict";
//------------------------------------------------------------------------------
// Requirements
//------------------------------------------------------------------------------
const typescriptParser = require('@typescript-eslint/parser')
var rule = require("../../../lib/rules/logic-dependency"),
RuleTester = require("eslint").RuleTester;
//------------------------------------------------------------------------------
// Tests
//------------------------------------------------------------------------------
typescriptParser.parseForESLint()
var ruleTester = new RuleTester({ parserOptions: {} });
ruleTester.run("logic-dependency", rule, {
valid: [
`class DeleteLogic {
}
class CreateLogic {
constructor(private deleteLogic: DeleteLogic) {}
}`
],
invalid: [
{
code: `class ExternalClient {
}
class UpdateLogic {
constructor(private externalClient: ExternalClient) {}
}`,
errors: [
{
message: "Logic cannot have a dependency on client",
type: "MethodDefinition"
}
]
}
]
});
现在我的测试失败了,因为默认情况下eslint只理解普通的Javascript代码。我知道我需要以某种方式将其配置为使用自定义解析器,使其能够理解/解析typescript代码。然而,我在网上找不到一个好的例子来说明如何做到这一点
发布于 2020-03-08 02:40:02
RuleTester构造函数接受允许配置parser itself的eslint的parser options。所以像这样传递它,Bob就是你的叔叔:
const ruleTester = new RuleTester({
parser: '@typescript-eslint/parser',
});typescript-eslint自己的规则测试(例如this one)就是这样使用的。
(我一直在寻找这个问题的答案,并一直在这里结束,所以我在这里发布了我在这里找到的解决方案,希望它会有用。)
eslint 6.0+
结合@Sonata的评论:
Eslint 6.0+需要解析器的绝对路径(请参阅6.0 migration guide):
const ruleTester = new RuleTester({
parser: require.resolve('@typescript-eslint/parser'),
});发布于 2020-02-22 02:04:15
使用诸如typescript-eslint/parser之类的包。在这种情况下,我只能提供一个链接。如果你需要使用它的帮助,请告诉我。
https://stackoverflow.com/questions/60111945
复制相似问题