Working towards getting date tests working for SQS.

This commit is contained in:
Sam Rose 2024-04-10 17:50:18 +01:00
parent 8483bdf0f7
commit a1164ac581
No known key found for this signature in database
3 changed files with 63 additions and 71 deletions

View File

@ -13,12 +13,12 @@ import {
jest.unmock("mssql") jest.unmock("mssql")
describe.each([ describe.each([
["internal", undefined], // ["internal", undefined],
["internal-sqs", undefined], ["internal-sqs", undefined],
[DatabaseName.POSTGRES, getDatasource(DatabaseName.POSTGRES)], // [DatabaseName.POSTGRES, getDatasource(DatabaseName.POSTGRES)],
[DatabaseName.MYSQL, getDatasource(DatabaseName.MYSQL)], // [DatabaseName.MYSQL, getDatasource(DatabaseName.MYSQL)],
[DatabaseName.SQL_SERVER, getDatasource(DatabaseName.SQL_SERVER)], // [DatabaseName.SQL_SERVER, getDatasource(DatabaseName.SQL_SERVER)],
[DatabaseName.MARIADB, getDatasource(DatabaseName.MARIADB)], // [DatabaseName.MARIADB, getDatasource(DatabaseName.MARIADB)],
])("/api/:sourceId/search (%s)", (name, dsProvider) => { ])("/api/:sourceId/search (%s)", (name, dsProvider) => {
const isSqs = name === "internal-sqs" const isSqs = name === "internal-sqs"
const config = setup.getConfig() const config = setup.getConfig()
@ -83,9 +83,6 @@ describe.each([
{ query: { equal: { name: "foo" } }, expected: [rows[0]] }, { query: { equal: { name: "foo" } }, expected: [rows[0]] },
{ query: { notEqual: { name: "foo" } }, expected: [rows[1]] }, { query: { notEqual: { name: "foo" } }, expected: [rows[1]] },
{ query: { oneOf: { name: ["foo"] } }, expected: [rows[0]] }, { query: { oneOf: { name: ["foo"] } }, expected: [rows[0]] },
// { query: { contains: { name: "f" } }, expected: [0] },
// { query: { notContains: { name: ["f"] } }, expected: [1] },
// { query: { containsAny: { name: ["f"] } }, expected: [0] },
] ]
it.each(stringSearchTests)( it.each(stringSearchTests)(
@ -171,7 +168,7 @@ describe.each([
) )
}) })
describe("dates", () => { describe.only("dates", () => {
beforeEach(async () => { beforeEach(async () => {
table = await config.api.table.save( table = await config.api.table.save(
tableForDatasource(datasource, { tableForDatasource(datasource, {
@ -186,8 +183,8 @@ describe.each([
}) })
const rows = [ const rows = [
{ dob: new Date("2020-01-01") }, { dob: new Date("2020-01-01").toISOString() },
{ dob: new Date("2020-01-10") }, { dob: new Date("2020-01-10").toISOString() },
] ]
interface DateSearchTest { interface DateSearchTest {
@ -196,70 +193,66 @@ describe.each([
} }
const dateSearchTests: DateSearchTest[] = [ const dateSearchTests: DateSearchTest[] = [
{ query: {}, expected: rows }, //{ query: {}, expected: rows },
//{
// query: { onEmptyFilter: EmptyFilterOption.RETURN_ALL },
// expected: rows,
//},
//{
// query: { onEmptyFilter: EmptyFilterOption.RETURN_NONE },
// expected: [],
//},
{ {
query: { onEmptyFilter: EmptyFilterOption.RETURN_ALL }, query: { equal: { dob: new Date("2020-01-01").toISOString() } },
expected: rows,
},
{
query: { onEmptyFilter: EmptyFilterOption.RETURN_NONE },
expected: [],
},
{
query: { equal: { dob: new Date("2020-01-01") } },
expected: [rows[0]], expected: [rows[0]],
}, },
{ query: { equal: { dob: new Date("2020-01-02") } }, expected: [] }, // { query: { equal: { dob: new Date("2020-01-02") } }, expected: [] },
{ // {
query: { notEqual: { dob: new Date("2020-01-01") } }, // query: { notEqual: { dob: new Date("2020-01-01") } },
expected: [rows[1]], // expected: [rows[1]],
}, // },
{ // {
query: { oneOf: { dob: [new Date("2020-01-01")] } }, // query: { oneOf: { dob: [new Date("2020-01-01")] } },
expected: [rows[0]], // expected: [rows[0]],
}, // },
{ // {
query: { // query: {
range: { // range: {
dob: { // dob: {
low: new Date("2020-01-01").toISOString(), // low: new Date("2020-01-01").toISOString(),
high: new Date("2020-01-05").toISOString(), // high: new Date("2020-01-05").toISOString(),
}, // },
}, // },
}, // },
expected: [rows[0]], // expected: [rows[0]],
}, // },
{ // {
query: { // query: {
range: { // range: {
dob: { // dob: {
low: new Date("2020-01-01").toISOString(), // low: new Date("2020-01-01").toISOString(),
high: new Date("2020-01-10").toISOString(), // high: new Date("2020-01-10").toISOString(),
}, // },
}, // },
}, // },
expected: rows, // expected: rows,
}, // },
{ // {
query: { // query: {
range: { // range: {
dob: { // dob: {
low: new Date("2020-01-05").toISOString(), // low: new Date("2020-01-05").toISOString(),
high: new Date("2020-01-10").toISOString(), // high: new Date("2020-01-10").toISOString(),
}, // },
}, // },
}, // },
expected: [rows[1]], // expected: [rows[1]],
}, // },
] ]
it.each(dateSearchTests)( it.each(dateSearchTests)(
`should be able to run query: $query`, `should be able to run query: $query`,
async ({ query, expected }) => { async ({ query, expected }) => {
// TODO(samwho): most of these work for SQS, but not all. Fix 'em.
if (isSqs) {
return
}
const savedRows = await Promise.all( const savedRows = await Promise.all(
rows.map(r => config.api.row.save(table._id!, r)) rows.map(r => config.api.row.save(table._id!, r))
) )
@ -270,9 +263,7 @@ describe.each([
expect(foundRows).toEqual( expect(foundRows).toEqual(
expect.arrayContaining( expect.arrayContaining(
expected.map(r => expected.map(r =>
expect.objectContaining( expect.objectContaining(savedRows.find(sr => sr.dob === r.dob)!)
savedRows.find(sr => sr.dob === r.dob.toISOString())!
)
) )
) )
) )

View File

@ -156,7 +156,7 @@ export async function search(
try { try {
const query = builder._query(request, { const query = builder._query(request, {
disableReturning: true, disableReturning: true,
disableBindings: true, disableBindings: false,
}) })
if (Array.isArray(query)) { if (Array.isArray(query)) {

View File

@ -74,6 +74,7 @@ export enum FilterType {
EMPTY = "empty", EMPTY = "empty",
NOT_EMPTY = "notEmpty", NOT_EMPTY = "notEmpty",
ONE_OF = "oneOf", ONE_OF = "oneOf",
CONTAINS = "contains",
} }
export enum DatasourceFeature { export enum DatasourceFeature {