如何修复预期值:“1”接收到的数组:[“COUNT (*)”:“1”] 在带有 jest 框架的 TypeORM 中出现错误

Posted

技术标签:

【中文标题】如何修复预期值:“1”接收到的数组:[“COUNT (*)”:“1”] 在带有 jest 框架的 TypeORM 中出现错误【英文标题】:How to fix Expected value: "1" Received array: ["COUNT (*)": "1"] error in TypeORM with jest framework如何修复预期值:“1”接收到的数组:[“COUNT (*)”:“1”] 在带有 jest 框架的 TypeORM 中出现错误 【发布时间】:2019-09-02 09:31:59 【问题描述】:

我是 Jest 框架和 TypeORM 的新手,我在运行 manager.query 语句时遇到问题

我正在连接到数据库,而不是使用查询构建器,我想使用实体管理器来注入原始查询。以下是代码 -

import createDBConnection from "../utils/createDBConnection";

test(" Count", async () =>
  jest.setTimeout(100000);
  const connection = await createDBConnection();
  const usercount= await connection.manager.query("SELECT COUNT (*) FROM User");
  expect(usercount).toContain('32');
);

以下是预期和实际输出。

expect(received).toContain(expected) // indexOf

    Expected value: "32"
    Received array: ["COUNT (*)": "32"]

【问题讨论】:

这不是原始查询的预期输出吗? 结果应该是 - 预期值:“32” 接收值:“32” 【参考方案1】:

您正在通过 TypeORMs API 运行原始查询。当您运行原始查询时,TypeORM 将返回原始结果,在本例中是来自 SQL 服务器的行数组。您需要解析结果以获取计数,例如:

const key = "user_count";
const usercount= await connection.manager.query(`SELECT COUNT (*) as $key FROM User`);
expect(usercount.length).toEqual(1);
expect(usercount[0][key]).toEqual("32");

您也可以使用存储库 API 来获取计数:

const usercount = await getRepository(User).count();
expect(usercount).toEqual(32);

【讨论】:

以上是关于如何修复预期值:“1”接收到的数组:[“COUNT (*)”:“1”] 在带有 jest 框架的 TypeORM 中出现错误的主要内容,如果未能解决你的问题,请参考以下文章

ValueError:层顺序的输入 0 与层不兼容:输入形状的预期轴 -1 具有值 3,但接收到的输入具有形状

输入形状的预期轴 -1 的值为 20,但接收到的输入形状为(无,29)

我的挤压功能没有按预期工作,我该怎么做才能修复这个功能?

如何接收和过滤来自报告的存储过程的数组数据是SAS

如何修复预期的字符串,但在带有改造的嵌套数组上是 BEGIN_OBJECT

如何在此 for 循环中修复'无法将'String'类型的值转换为预期的参数类型'Int'