mirror of
https://github.com/TheAnachronism/docspell.git
synced 2025-06-23 02:48:26 +00:00
Convert find items query
This commit is contained in:
@ -48,14 +48,14 @@ object QueryBuilderTest extends SimpleTestSuite {
|
||||
assertEquals(f, FromExpr.From(c))
|
||||
assertEquals(2, joins.size)
|
||||
joins.head match {
|
||||
case Join.InnerJoin(tbl, cond) =>
|
||||
case FromExpr.Join.InnerJoin(FromExpr.Relation.Table(tbl), cond) =>
|
||||
assertEquals(tbl, owner)
|
||||
assertEquals(cond, c.ownerId === owner.id)
|
||||
case _ =>
|
||||
fail("Unexpected join result")
|
||||
}
|
||||
joins.tail.head match {
|
||||
case Join.LeftJoin(tbl, cond) =>
|
||||
case FromExpr.Join.LeftJoin(FromExpr.Relation.Table(tbl), cond) =>
|
||||
assertEquals(tbl, lecturer)
|
||||
assertEquals(cond, c.lecturerId === lecturer.id)
|
||||
case _ =>
|
||||
|
@ -0,0 +1,19 @@
|
||||
package docspell.store.qb.impl
|
||||
|
||||
import minitest._
|
||||
import docspell.store.qb._
|
||||
import docspell.store.qb.DSL._
|
||||
import docspell.store.qb.model.{CourseRecord, PersonRecord}
|
||||
|
||||
object DSLTest extends SimpleTestSuite {
|
||||
|
||||
val course = CourseRecord.as("c")
|
||||
val person = PersonRecord.as("p")
|
||||
|
||||
test("and") {
|
||||
val c = course.lessons > 4 && person.id === 3 && person.name.like("%a%")
|
||||
val expect =
|
||||
Condition.And(course.lessons > 4, person.id === 3, person.name.like("%a%"))
|
||||
assertEquals(c, expect)
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user