首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jest/ts/ tests找不到名称'x‘

jest/ts/ tests找不到名称'x‘
EN

Stack Overflow用户
提问于 2019-08-26 18:24:50
回答 1查看 707关注 0票数 2

我已经读了一大堆关于这个的问题,但是,似乎没有一个问题能解决我的任何问题。

index.test.ts

代码语言:javascript
复制
import request from 'supertest';
import * as server from '../server';
import 'jest'

//close server after each request
afterEach( //cannot find name 'afterEach'
  async (): Promise<void> => {
    await server.close(); // Property 'close' does not exist on type 'typeof import(<path to file)'
  },
);

describe('get /', (): void => { //Cannot find name 'describe'. Do you need to install type definitions for a test runner? Try `npm i @types/jest` or `npm i @types/mocha`
  it('should respond as expected', async (): Promise<void> => {// cannot find 'it'...
    const response = await request(server).get('/');
    expect(response.status).toEqual(200); // cannot find 'expect'
    expect(response.body.data).toEqual('Sending some JSON'); // cannot find 'expect'...
  });
});

我已经安装了jest和mocha类型,只是为了确保它不会将一个注册到另一个之上。几乎所有的东西都没有被识别,.babelrcc

代码语言:javascript
复制
{
  "presets": ["@babel/preset-typescript"]
}

jest.config.js

代码语言:javascript
复制
module.exports = {
  preset: 'ts-jest',
  testEnvironment: 'node',
  transform: {
    '^.+\\.tsx?$': 'ts-jest',
  },
};

tsconfig.json

代码语言:javascript
复制
{
  "compilerOptions": {
    "module": "commonjs",
    "target": "es6",
    "noImplicitAny": true,
    "preserveConstEnums": true,
    "outDir": "./dist",
    "sourceMap": true,
    "esModuleInterop": true
  },
  "include": ["./src/**/*"],
  "exclude": ["test", "**/*/spec.ts", "**/*/test.ts"]
}

服务器

代码语言:javascript
复制
import * as dotenv from 'dotenv';
dotenv.config();
import Koa from 'koa';
import logger from 'koa-logger';
import apiRoutes from './Routes';
import cors from '@koa/cors';
import bodyParser from 'koa-bodyparser';
const app = new Koa();
const PORT = process.env.PORT || 3001;
const ENV = process.env.NODE_ENV || 'Development';

app.use(logger());
app.use(cors());
app.use(bodyParser());
app.use(apiRoutes);

export const server = app.listen(PORT, (): void => {
  console.log(`? Server listening on port ${PORT} - ${ENV} environment`);
});

我不知道还有哪些信息是相关的,如果我遗漏了其他信息,我会用这些信息更新

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-08-27 20:13:27

当您尝试将命名变量server作为默认导出进行导入时,您将直接导出该变量。

只需在index.test.ts中将其更改为import { server } from './server';,它就会像预期的那样工作。您也可以在server.ts中将导出更改为export default server,但基于this article,我倾向于避免这样做。

阅读更多about export on MDN

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57656089

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档