public void OperationTest() { AQuery query = _db.Query .Let("x", AValue.Op(AValue <Dummy> .Field(x => x.Baz), "/", AValue <Dummy> .Field(x => x.Bar))); Assert.AreEqual("LET x = (x.Baz / x.Bar)", query.GetExpression()); }
public void ForTest() { AQuery query = _db.Query .For("x", AValue.Field(TestDocumentCollectionName)); Assert.AreEqual("FOR x IN " + TestDocumentCollectionName, query.GetExpression()); }
public void AttributesTest() { AQuery query = _db.Query .Let("x", AValue.Attributes(AValue <Dummy> .Field(x => x.Foo))); Assert.AreEqual("LET x = ATTRIBUTES(x.Foo)", query.GetExpression()); }
public void SortTest() { AQuery query = _db.Query .Sort(AValue <Dummy> .Field(x => x.Foo), AqlSort.Direction.Desc); Assert.AreEqual("SORT x.Foo DESC", query.GetExpression()); }
public void FieldSuffixTest() { AQuery query = _db.Query .Let("x", AValue <Dummy> .Field <int>(x => x.Foo, ".was")); Assert.AreEqual("LET x = x.Foo.was", query.GetExpression()); }
public void FieldTest() { AQuery query = _db.Query .Let("x", AValue <Dummy> .Field(x => x.Bar)); Assert.AreEqual("LET x = x.Bar", query.GetExpression()); }
public void ObjectTest() { AQuery query = _db.Query .Let("x", AValue <Dummy> .Object( ( x => x.Id, AValue.Bind("asdf") ), ( x => x.Foo, AValue <Dummy> .Field(z => z.Foo) ), ( x => x.Bar, AValue.Bind(10) ), ( x => x.Baz, AValue <Dummy> .Field(x => x.Bar) ) )); Assert.AreEqual("LET x = {\"_id\":@var0,\"Foo\":z.Foo,\"Bar\":@var1,\"Baz\":x.Bar}", query.GetExpression()); Assert.AreEqual(typeof(string), query.GetBindedVars()[0].GetType()); Assert.AreEqual(typeof(int), query.GetBindedVars()[1].GetType()); }
public void BetweenTest() { AQuery query = _db.Query.Filter(AFilter.Between(AValue <Dummy> .Field(x => x.Bar), AValue.Bind(1), AValue.Bind(50))); Assert.AreEqual("FILTER (x.Bar >= @var0 AND x.Bar <= @var1)", query.GetExpression()); Assert.AreEqual(1, query.GetBindedVars()[0]); Assert.AreEqual(50, query.GetBindedVars()[1]); }
public void SimpleTest() { //AQuery query = _db.Query.Filter(FilterBuilder<Dummy>.Eq( x => x.Foo, "asd")); AQuery query = _db.Query.Filter(AFilter.Eq(AValue <Dummy> .Field(x => x.Foo), AValue.Bind("asd"))); Assert.AreEqual("FILTER x.Foo == @var0", query.GetExpression()); Assert.AreEqual("asd", query.GetBindedVars()[0]); }
public void InTest() { //AQuery query = _db.Query.Filter(FilterBuilder<Dummy>.In(x => x.Foo, new[] {"asd", "qwe"})); AQuery query = _db.Query.Filter(AFilter.In(AValue <Dummy> .Field(x => x.Foo), AValueArray.Bind("asd", "qwe"))); Assert.AreEqual("FILTER x.Foo IN [@var0,@var1]", query.GetExpression()); Assert.AreEqual("asd", query.GetBindedVars()[0]); Assert.AreEqual("qwe", query.GetBindedVars()[1]); }
public void TypeTest() { Type dummyType = typeof(Dummy); //AQuery query = _db.Query.Filter(FilterBuilder<Dummy>.Eq(x => x.GetType(), dummyType)); AQuery query = _db.Query.Filter(AFilter.Eq(AValue <Dummy> .Field(x => x.GetType()), AValue.Bind(dummyType))); Assert.AreEqual("FILTER x.$type == @var0", query.GetExpression()); Assert.AreEqual(dummyType.FullName + ", " + dummyType.Assembly.GetName().Name, query.GetBindedVars()[0]); }
public void MultipleTest() { AQuery query = _db.Query //.Filter(FilterBuilder<Dummy>.Lt(x => x.Baz, 50)) //.Filter(FilterBuilder<Dummy>.Gte(x => x.Bar, 1)); .Filter(AFilter.Lt(AValue <Dummy> .Field(x => x.Baz), AValue.Bind(50))) .Filter(AFilter.Gte(AValue <Dummy> .Field(x => x.Bar), AValue.Bind(1))); Assert.AreEqual("FILTER x.Baz < @var0 FILTER x.Bar >= @var1", query.GetExpression()); Assert.AreEqual(50, query.GetBindedVars()[0]); Assert.AreEqual(1, query.GetBindedVars()[1]); }
public void IfTest() { AQuery query = _db.Query .Let("x", AValue.If( AFilter.Eq(AValue <Dummy> .Field(x => x.Bar), AValue.Bind(2)), AValue <Dummy> .Field(x => x.Baz), AValue.Bind(0) )); Assert.AreEqual("LET x = (x.Bar == @var0 ? x.Baz : @var1)", query.GetExpression()); Assert.AreEqual(2, query.GetBindedVars()[0]); Assert.AreEqual(0, query.GetBindedVars()[1]); }
public void OrTest() { AQuery query = _db.Query.Filter( AFilter.Or( AFilter.Eq(AValue <Dummy> .Field(x => x.Foo), AValue.Bind("asd")), AFilter.Gt(AValue <Dummy> .Field(x => x.Bar), AValue.Bind(1)) ) ); Assert.AreEqual("FILTER (x.Foo == @var0 OR x.Bar > @var1)", query.GetExpression()); Assert.AreEqual("asd", query.GetBindedVars()[0]); Assert.AreEqual(1, query.GetBindedVars()[1]); }
public void LetSubQueryTest() { AQuery subquery = _db.Query .For("y", AValue.Field(TestDocumentCollectionName)) .Collect() .Aggregate("max", ANumeric.Max(AValue.Field("y.value"))) .Return(AReturn.Variable("max")); AQuery query = _db.Query .Let("x", AValue.Subquery <int>(subquery)); Assert.AreEqual("LET x = (FOR y IN " + TestDocumentCollectionName + " COLLECT AGGREGATE max = MAX(y.value) RETURN max)", query.GetExpression()); }
public void ObjectDynamicTest() { AQuery query = _db.Query .Let("x", AValue.Object( ( "_id", AValue.Bind("asdf") ), ( "Foo", AValue <Dummy> .Field(z => z.Foo) ), ( "lalalal", AValue.Bind(10) ) )); Assert.AreEqual("LET x = {\"_id\":@var0,\"Foo\":z.Foo,\"lalalal\":@var1}", query.GetExpression()); Assert.AreEqual(typeof(string), query.GetBindedVars()[0].GetType()); Assert.AreEqual(typeof(int), query.GetBindedVars()[1].GetType()); }
public void LetTest() { AQuery query = _db.Query .Let("x", AValue.Document <Dummy>(TestDocumentCollectionName, AValue.Field <string>("asd"))); Assert.AreEqual("LET x = DOCUMENT('" + TestDocumentCollectionName + "',asd)", query.GetExpression()); }