aboutsummaryrefslogtreecommitdiff
path: root/src/test/scala/xyz/driver/pdsuicommon/db/SearchFilterExprSuite.scala
diff options
context:
space:
mode:
authorvlad <vlad@driver.xyz>2017-06-13 16:12:20 -0700
committervlad <vlad@driver.xyz>2017-06-13 16:12:20 -0700
commitcd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c (patch)
tree062e8dad1a1513e26b0fd08b1742d6ff2ee874f7 /src/test/scala/xyz/driver/pdsuicommon/db/SearchFilterExprSuite.scala
parent0000a65ab4479a2a40e2d6468036438e9705b4aa (diff)
downloadrest-query-cd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c.tar.gz
rest-query-cd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c.tar.bz2
rest-query-cd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c.zip
Adding domain entitiesv0.1.0
Diffstat (limited to 'src/test/scala/xyz/driver/pdsuicommon/db/SearchFilterExprSuite.scala')
-rw-r--r--src/test/scala/xyz/driver/pdsuicommon/db/SearchFilterExprSuite.scala32
1 files changed, 32 insertions, 0 deletions
diff --git a/src/test/scala/xyz/driver/pdsuicommon/db/SearchFilterExprSuite.scala b/src/test/scala/xyz/driver/pdsuicommon/db/SearchFilterExprSuite.scala
new file mode 100644
index 0000000..ee467af
--- /dev/null
+++ b/src/test/scala/xyz/driver/pdsuicommon/db/SearchFilterExprSuite.scala
@@ -0,0 +1,32 @@
+package xyz.driver.pdsuicommon.db
+
+import org.scalatest.{FreeSpecLike, MustMatchers}
+
+class SearchFilterExprSuite extends FreeSpecLike with MustMatchers {
+
+ "replace" - {
+ "all entities are changed" in {
+ val ast = SearchFilterExpr.Union(Seq(
+ SearchFilterExpr.Intersection(Seq(
+ SearchFilterExpr.Atom.Binary("foo", SearchFilterBinaryOperation.Gt, "10"),
+ SearchFilterExpr.Atom.Binary("foo", SearchFilterBinaryOperation.Lt, "20")
+ )),
+ SearchFilterExpr.Atom.NAry("bar", SearchFilterNAryOperation.In, Seq("x", "y", "z")),
+ SearchFilterExpr.Atom.Binary("foo", SearchFilterBinaryOperation.Eq, "40")
+ ))
+
+ val newAst = ast.replace {
+ case x: SearchFilterExpr.Atom.Binary if x.dimension.name == "foo" =>
+ x.copy(dimension = x.dimension.copy(name = "bar"))
+ }
+
+ val result = newAst.find {
+ case x: SearchFilterExpr.Atom.Binary => x.dimension.name == "foo"
+ case _ => false
+ }
+
+ result mustBe empty
+ }
+ }
+
+}