2024-04-09 16:09:56 +02:00
|
|
|
import { tableForDatasource } from "../../../tests/utilities/structures"
|
|
|
|
import { DatabaseName, getDatasource } from "../../../integrations/tests/utils"
|
|
|
|
|
|
|
|
import * as setup from "./utilities"
|
2024-04-09 19:13:18 +02:00
|
|
|
import { Datasource, FieldType, SearchFilters, Table } from "@budibase/types"
|
2024-04-09 16:09:56 +02:00
|
|
|
|
|
|
|
jest.unmock("mssql")
|
|
|
|
|
|
|
|
describe.each([
|
2024-04-09 17:48:54 +02:00
|
|
|
["internal", undefined],
|
2024-04-09 16:09:56 +02:00
|
|
|
["internal-sqs", undefined],
|
2024-04-09 17:48:54 +02:00
|
|
|
[DatabaseName.POSTGRES, getDatasource(DatabaseName.POSTGRES)],
|
|
|
|
[DatabaseName.MYSQL, getDatasource(DatabaseName.MYSQL)],
|
|
|
|
[DatabaseName.SQL_SERVER, getDatasource(DatabaseName.SQL_SERVER)],
|
|
|
|
[DatabaseName.MARIADB, getDatasource(DatabaseName.MARIADB)],
|
2024-04-09 16:09:56 +02:00
|
|
|
])("/api/:sourceId/search (%s)", (name, dsProvider) => {
|
|
|
|
const isSqs = name === "internal-sqs"
|
|
|
|
const config = setup.getConfig()
|
|
|
|
|
|
|
|
let envCleanup: (() => void) | undefined
|
|
|
|
let table: Table
|
|
|
|
let datasource: Datasource | undefined
|
|
|
|
|
|
|
|
beforeAll(async () => {
|
|
|
|
if (isSqs) {
|
|
|
|
envCleanup = config.setEnv({ SQS_SEARCH_ENABLE: "true" })
|
|
|
|
}
|
|
|
|
await config.init()
|
|
|
|
if (dsProvider) {
|
|
|
|
datasource = await config.createDatasource({
|
|
|
|
datasource: await dsProvider,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
afterAll(async () => {
|
|
|
|
setup.afterAll()
|
|
|
|
if (envCleanup) {
|
|
|
|
envCleanup()
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
beforeEach(async () => {
|
|
|
|
table = await config.api.table.save(
|
|
|
|
tableForDatasource(datasource, {
|
|
|
|
schema: {
|
|
|
|
name: {
|
|
|
|
name: "name",
|
|
|
|
type: FieldType.STRING,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
)
|
|
|
|
})
|
|
|
|
|
2024-04-09 19:09:37 +02:00
|
|
|
describe("strings", () => {
|
2024-04-10 10:30:01 +02:00
|
|
|
const rows = [{ name: "foo" }, { name: "bar" }]
|
|
|
|
|
2024-04-09 19:09:37 +02:00
|
|
|
interface StringSearchTest {
|
|
|
|
query: SearchFilters
|
2024-04-10 10:30:01 +02:00
|
|
|
expected: (typeof rows)[number][]
|
2024-04-09 19:09:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
const stringSearchTests: StringSearchTest[] = [
|
2024-04-10 10:30:01 +02:00
|
|
|
{ query: {}, expected: rows },
|
|
|
|
{ query: { string: { name: "foo" } }, expected: [rows[0]] },
|
|
|
|
{ query: { fuzzy: { name: "oo" } }, expected: [rows[0]] },
|
|
|
|
{ query: { equal: { name: "foo" } }, expected: [rows[0]] },
|
|
|
|
{ query: { notEqual: { name: "foo" } }, expected: [rows[1]] },
|
|
|
|
{ query: { oneOf: { name: ["foo"] } }, expected: [rows[0]] },
|
2024-04-09 19:09:37 +02:00
|
|
|
// { query: { contains: { name: "f" } }, expected: [0] },
|
|
|
|
// { query: { notContains: { name: ["f"] } }, expected: [1] },
|
|
|
|
// { query: { containsAny: { name: ["f"] } }, expected: [0] },
|
|
|
|
]
|
|
|
|
|
|
|
|
it.each(stringSearchTests)(
|
|
|
|
`should be able to run query: $query`,
|
|
|
|
async ({ query, expected }) => {
|
2024-04-10 10:30:01 +02:00
|
|
|
await Promise.all(rows.map(r => config.api.row.save(table._id!, r)))
|
|
|
|
const { rows: foundRows } = await config.api.row.search(table._id!, {
|
2024-04-09 19:09:37 +02:00
|
|
|
tableId: table._id!,
|
|
|
|
query,
|
|
|
|
})
|
2024-04-10 10:30:01 +02:00
|
|
|
expect(foundRows).toEqual(
|
|
|
|
expect.arrayContaining(expected.map(r => expect.objectContaining(r)))
|
2024-04-09 19:09:37 +02:00
|
|
|
)
|
|
|
|
}
|
2024-04-09 16:09:56 +02:00
|
|
|
)
|
|
|
|
})
|
|
|
|
})
|