在打字稿上扩展超级测试

Jon*_*zzi 3 testing bdd node.js typescript supertest

我正在尝试在 supertest 上创建一个扩展。

使用我在问题Extending SuperTest 中发现的内容。我有这个工作示例javascript

const request = require('supertest');
const Test = request.Test;

Test.prototype.authenticate = function(user) {
  const {token, xsrfToken} = user.tokens;

  return this
   .set('Authorization', `Bearer ${token}`)
   .set('X-XSRF-TOKEN', xsrfToken);
}
Run Code Online (Sandbox Code Playgroud)

在测试块内,我可以使用:

request(app)
  .post('/user/settings')
  .authenticate(user)
  .send(...)
Run Code Online (Sandbox Code Playgroud)

这工作正常。现在的问题是在*.test.ts文件中使用扩展名。

正如使用 Typescript 扩展 Express Request 对象中所建议的那样,我尝试创建一个文件以使用typescript功能 Declaration Merging

// file location: ./src/types/supertest

declare namespace supertest {
  export interface Test {
    authenticate(user: any): this; // I didn't put a type on user to simplify here.
  }
}
Run Code Online (Sandbox Code Playgroud)

也改变了我的 tsconfig.json

{
  "compilerOptions": {

    ...

    "typeRoots": ["./src/types"],

    ...

  }
}
Run Code Online (Sandbox Code Playgroud)

但是当我跑 npx tsc

$ npx tsc
src/api/user.test.ts:51:8 - error TS2551: Property 'authenticate' does not exist on type 'Test'.

51       .authenticate(user);
          ~~~~~~~
Run Code Online (Sandbox Code Playgroud)

问题
有没有办法在打字稿环境中解决这个问题?

[编辑]
额外信息(不一定有用):
在同一个项目中,我对express,chaipdf-merge-js. 使用上述方法,所有这些都可以正常工作。

也有一些特别之处supertest,也许大约@types/supertest是其预防工作。

这是我项目中的一小部分代码,这些代码已经可以用于 express 了:

// file location: ./src/types/express
import { ModelBase } from '../../models/base';

declare global {
  namespace Express {
    export interface Response {
      model: (model: ModelBase) => this;
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

小智 8

这对我来说效果很好。

首先我导入了类型

npm i -D @types/supertest  
Run Code Online (Sandbox Code Playgroud)

然后我用过

import { agent as request } from "supertest"; 
Run Code Online (Sandbox Code Playgroud)


Max*_*rok 5

我不确定为什么,但这对我有用:

declare module "supertest" {
  interface Test extends superagent.SuperAgentRequest {
    authenticate(user: any): this;
  }
}
Run Code Online (Sandbox Code Playgroud)

结构:

index.ts
tsconfig.json
types
  - supertest
    - index.d.ts
Run Code Online (Sandbox Code Playgroud)

我的index.ts

import request from "supertest";
import express from "express";

const app = express();

app.get("/user", function (req, res) {
  res.status(200).json({ name: "john" });
});

request(app)
  .post("/user/settings")
  .authenticate({ tokens: { token: "", xsrfToken: "" } })
  .send();
Run Code Online (Sandbox Code Playgroud)

我的tsconfig.json

{
  "compilerOptions": {
    "outDir": "dist",
    "rootDir": ".",
    "typeRoots": ["./types", "./node_modules/@types"],
    "esModuleInterop": true
  },
  "files": ["./types/supertest/index.d.ts", "index.ts"]
}
Run Code Online (Sandbox Code Playgroud)

我的types/supertest/index.d.ts

import superagent from "superagent";

declare module "supertest" {
  interface Test extends superagent.SuperAgentRequest {
    authenticate(user: any): this;
  }
}
Run Code Online (Sandbox Code Playgroud)

我认为这declare module "supertest"是关键部分。其他一切你都做对了。

  • 即使没有对“tsconfig.json”进行更改,这也能正常工作。多谢。 (2认同)