Как исправить ожидаемое значение: «1» Полученный массив: [{«COUNT (*)»: «1»}] ошибка в TypeORM с Jest Framework - PullRequest
1 голос
/ 11 апреля 2019

Я новичок в Jest Framework и 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"}]

1 Ответ

1 голос
/ 12 апреля 2019

Вы выполняете необработанный запрос через API-интерфейс TypeORM.Когда вы запустите необработанный запрос, 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);
...