commit ac82511ddd17d5472ae3cfea9bbad9754f5a4d62 Author: Simon Cambier <simon.cambier@protonmail.com> Date: Sat Oct 22 08:23:42 2022 +0200 Screw that cache, seriously. commit 8ba40d1be73daaaffea09e07bc56c339266db9b6 Author: Simon Cambier <simon.cambier@protonmail.com> Date: Fri Oct 21 22:36:48 2022 +0200 Stuff commit 27b8fd7dc809be9714a109d3a458eb1276a47e2e Author: Simon Cambier <simon.cambier@protonmail.com> Date: Fri Oct 21 22:22:20 2022 +0200 Moved files commit fb1349c914907e586e103ca54fb04b9ddd45ef5d Author: Simon Cambier <simon.cambier@protonmail.com> Date: Thu Oct 20 22:25:29 2022 +0200 Removed duplicate code commit e7371138e60cbe4155cfd4fb44e3ee1d2e3ee088 Author: Simon Cambier <simon.cambier@protonmail.com> Date: Thu Oct 20 21:50:09 2022 +0200 Moved a bunch of files commit 2ee1b2a0e799d4b41ab3a444d8cc44dfff5b5623 Author: Simon Cambier <simon.cambier@protonmail.com> Date: Thu Oct 20 21:32:21 2022 +0200 Removed useless code commit 76c530dfb9adbad1bbe9079de2330fe43a044249 Author: Simon Cambier <simon.cambier@protonmail.com> Date: Thu Oct 20 20:44:11 2022 +0200 Split file reading and indexing
61 lines
1.8 KiB
TypeScript
61 lines
1.8 KiB
TypeScript
import { Query } from '../search/query'
|
|
|
|
describe('The Query class', () => {
|
|
const stringQuery =
|
|
"foo bar 'lorem ipsum' -baz dolor \"sit amet\" -'quoted exclusion'"
|
|
|
|
it('should correctly parse string queries', () => {
|
|
// Act
|
|
const query = new Query(stringQuery)
|
|
|
|
// Assert
|
|
const segments = query.segments.map(s => s.value)
|
|
expect(segments).toHaveLength(5)
|
|
expect(segments).toContain('foo')
|
|
expect(segments).toContain('bar')
|
|
expect(segments).toContain('lorem ipsum')
|
|
expect(segments).toContain('dolor')
|
|
expect(segments).toContain('sit amet')
|
|
|
|
const exclusions = query.exclusions.map(s => s.value)
|
|
expect(exclusions).toHaveLength(2)
|
|
expect(exclusions).toContain('baz')
|
|
expect(exclusions).toContain('quoted exclusion')
|
|
})
|
|
|
|
it('should mark quoted segments & exclusions as "exact"', () => {
|
|
// Act
|
|
const query = new Query(stringQuery)
|
|
|
|
// Assert
|
|
expect(query.segments.filter(s => s.exact)).toHaveLength(2)
|
|
expect(
|
|
query.segments.find(o => o.value === 'lorem ipsum')!.exact
|
|
).toBeTruthy()
|
|
expect(query.segments.find(o => o.value === 'sit amet')!.exact).toBeTruthy()
|
|
|
|
expect(query.exclusions.filter(s => s.exact)).toHaveLength(1)
|
|
expect(
|
|
query.exclusions.find(o => o.value === 'quoted exclusion')!.exact
|
|
).toBeTruthy()
|
|
})
|
|
|
|
it('should not exclude words when there is no space before', () => {
|
|
// Act
|
|
const query = new Query('foo bar-baz')
|
|
|
|
// Assert
|
|
expect(query.exclusions).toHaveLength(0)
|
|
})
|
|
|
|
describe('.getExactTerms()', () => {
|
|
it('should an array of strings containg "exact" values', () => {
|
|
// Act
|
|
const query = new Query(stringQuery)
|
|
|
|
// Assert
|
|
expect(query.getExactTerms()).toEqual(['lorem ipsum', 'sit amet'])
|
|
})
|
|
})
|
|
})
|