This commit is contained in:
@@ -762,11 +762,6 @@ namespace AyaNova.Biz
|
|||||||
sb.Append("<=");
|
sb.Append("<=");
|
||||||
sb.Append(sValue);
|
sb.Append(sValue);
|
||||||
break;
|
break;
|
||||||
// case "Like":
|
|
||||||
// sb.Append("Like N'");
|
|
||||||
// sb.Append(sValue);
|
|
||||||
// sb.Append("%'");
|
|
||||||
// break;
|
|
||||||
case FilterComparisonOperator.NotEqual:
|
case FilterComparisonOperator.NotEqual:
|
||||||
sb.Append("<>");
|
sb.Append("<>");
|
||||||
sb.Append(sValue);
|
sb.Append(sValue);
|
||||||
|
|||||||
@@ -23,6 +23,7 @@ namespace AyaNova.Models
|
|||||||
public DateTime? StartDate { get; set; }
|
public DateTime? StartDate { get; set; }
|
||||||
public DateTime? EndDate { get; set; }
|
public DateTime? EndDate { get; set; }
|
||||||
public string Notes { get; set; }
|
public string Notes { get; set; }
|
||||||
|
public int Count {get;set;}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -205,7 +205,7 @@ namespace AyaNova.Util
|
|||||||
//Add widget table
|
//Add widget table
|
||||||
//id, text, longtext, boolean, currency,
|
//id, text, longtext, boolean, currency,
|
||||||
exec("CREATE TABLE awidget (id BIGSERIAL PRIMARY KEY, ownerid bigint not null, name varchar(255) not null, serial bigint not null," +
|
exec("CREATE TABLE awidget (id BIGSERIAL PRIMARY KEY, ownerid bigint not null, name varchar(255) not null, serial bigint not null," +
|
||||||
"startdate timestamp, enddate timestamp, dollaramount decimal(19,5), active bool, roles int4, notes text)");
|
"startdate timestamp, enddate timestamp, dollaramount decimal(19,5), active bool, roles int4, count integer, notes text)");
|
||||||
|
|
||||||
//TEST TEST TEST ONLY FOR DEVELOPMENT TESTING TO ENSURE UNIQUENESS
|
//TEST TEST TEST ONLY FOR DEVELOPMENT TESTING TO ENSURE UNIQUENESS
|
||||||
//exec("CREATE UNIQUE INDEX awidget_serial_idx ON awidget (serial);");
|
//exec("CREATE UNIQUE INDEX awidget_serial_idx ON awidget (serial);");
|
||||||
|
|||||||
@@ -52,9 +52,154 @@ namespace raven_integration
|
|||||||
//TODO: Specifically test a string with an apostrophe in it (for inclusive, finding ti)
|
//TODO: Specifically test a string with an apostrophe in it (for inclusive, finding ti)
|
||||||
//TODO: specifically test a string with an ampersand character in it for inclusive (finding it)
|
//TODO: specifically test a string with an ampersand character in it for inclusive (finding it)
|
||||||
|
|
||||||
|
|
||||||
///////////////////////
|
///////////////////////
|
||||||
//INT
|
//INT
|
||||||
//
|
//
|
||||||
|
/**
|
||||||
|
|
||||||
|
case FilterComparisonOperator.Equality:
|
||||||
|
sb.Append("=");
|
||||||
|
sb.Append(sValue);
|
||||||
|
break;
|
||||||
|
case FilterComparisonOperator.GreaterThan:
|
||||||
|
sb.Append(">");
|
||||||
|
sb.Append(sValue);
|
||||||
|
break;
|
||||||
|
case FilterComparisonOperator.GreaterThanOrEqualTo:
|
||||||
|
sb.Append(">=");
|
||||||
|
sb.Append(sValue);
|
||||||
|
break;
|
||||||
|
case FilterComparisonOperator.LessThan:
|
||||||
|
sb.Append("<");
|
||||||
|
sb.Append(sValue);
|
||||||
|
break;
|
||||||
|
case FilterComparisonOperator.LessThanOrEqualTo:
|
||||||
|
sb.Append("<=");
|
||||||
|
sb.Append(sValue);
|
||||||
|
break;
|
||||||
|
case FilterComparisonOperator.NotEqual:
|
||||||
|
*/
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
///
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public async void IntegerOpEqualityFilterWorks()
|
||||||
|
{
|
||||||
|
|
||||||
|
//OPS: equal to, not equal to
|
||||||
|
//values: true, false
|
||||||
|
|
||||||
|
var WidgetNameStart = "IntegerDataFilterTest";
|
||||||
|
|
||||||
|
long IncludedWidgetId = 0;
|
||||||
|
long ExcludedWidgetId = 0;
|
||||||
|
|
||||||
|
//CREATE TEST WIDGETS
|
||||||
|
|
||||||
|
|
||||||
|
//included widget
|
||||||
|
dynamic w = new JObject();
|
||||||
|
w.name = Util.Uniquify(WidgetNameStart);
|
||||||
|
w.active = true;
|
||||||
|
w.roles = 0;
|
||||||
|
w.count = 555;
|
||||||
|
|
||||||
|
ApiResponse a = await Util.PostAsync("Widget", await Util.GetTokenAsync("manager", "l3tm3in"), w.ToString());
|
||||||
|
Util.ValidateDataReturnResponseOk(a);
|
||||||
|
IncludedWidgetId = a.ObjectResponse["data"]["id"].Value<long>();
|
||||||
|
|
||||||
|
//Excluded widget
|
||||||
|
w.name = Util.Uniquify(WidgetNameStart);
|
||||||
|
w.count = 333;
|
||||||
|
a = await Util.PostAsync("Widget", await Util.GetTokenAsync("manager", "l3tm3in"), w.ToString());
|
||||||
|
Util.ValidateDataReturnResponseOk(a);
|
||||||
|
ExcludedWidgetId = a.ObjectResponse["data"]["id"].Value<long>();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//CREATE FILTER
|
||||||
|
dynamic d = new JObject();
|
||||||
|
d.name = Util.Uniquify("Test INT DataFilter");
|
||||||
|
// d.ownerId = 1L;
|
||||||
|
d["public"] = true;
|
||||||
|
d.listKey = "widget";
|
||||||
|
|
||||||
|
dynamic dfilter = new JArray();
|
||||||
|
|
||||||
|
//name starts with filter to constrict to widgets that this test block created only
|
||||||
|
dynamic DataFilterNameStart = new JObject();
|
||||||
|
DataFilterNameStart.fld = "name";
|
||||||
|
DataFilterNameStart.op = OpStartsWith;
|
||||||
|
DataFilterNameStart.value = WidgetNameStart;
|
||||||
|
dfilter.Add(DataFilterNameStart);
|
||||||
|
|
||||||
|
//inclusive test filter
|
||||||
|
|
||||||
|
HERE
|
||||||
|
|
||||||
|
dynamic DataFilterActive = new JObject();
|
||||||
|
DataFilterActive.fld = "active";
|
||||||
|
DataFilterActive.op = OpEquality;
|
||||||
|
DataFilterActive.value = true;
|
||||||
|
dfilter.Add(DataFilterActive);
|
||||||
|
|
||||||
|
d.filter = dfilter.ToString();//it expects it to be a json string, not actual json
|
||||||
|
|
||||||
|
a = await Util.PostAsync("DataFilter", await Util.GetTokenAsync("BizAdminFull"), d.ToString());
|
||||||
|
Util.ValidateDataReturnResponseOk(a);
|
||||||
|
|
||||||
|
long DataFilterId = a.ObjectResponse["data"]["id"].Value<long>();
|
||||||
|
|
||||||
|
//NOW FETCH WIDGET LIST WITH FILTER
|
||||||
|
a = await Util.GetAsync($"Widget/listwidgets?DataFilterId={DataFilterId.ToString()}", await Util.GetTokenAsync("manager", "l3tm3in"));
|
||||||
|
Util.ValidateDataReturnResponseOk(a);
|
||||||
|
Util.ValidateHTTPStatusCode(a, 200);
|
||||||
|
|
||||||
|
//assert contains at least two records
|
||||||
|
((JArray)a.ObjectResponse["data"]).Count.Should().BeGreaterThan(1);
|
||||||
|
var v = ((JArray)a.ObjectResponse["data"]);
|
||||||
|
List<long> IDInResultList = new List<long>();
|
||||||
|
int nActiveMatches = 0;
|
||||||
|
int nInactiveMatches = 0;
|
||||||
|
foreach (JObject o in v)
|
||||||
|
{
|
||||||
|
if (ActiveWidgetIdList.Contains(o["id"].Value<long>()))
|
||||||
|
nActiveMatches++;
|
||||||
|
if (NotActiveWidgetIdList.Contains(o["id"].Value<long>()))
|
||||||
|
nInactiveMatches++;
|
||||||
|
}
|
||||||
|
|
||||||
|
nActiveMatches.Should().Be(ActiveWidgetIdList.Count);
|
||||||
|
nInactiveMatches.Should().Be(0);
|
||||||
|
|
||||||
|
//DELETE WIDGETS
|
||||||
|
foreach (long l in ActiveWidgetIdList)
|
||||||
|
{
|
||||||
|
a = await Util.DeleteAsync("Widget/" + l.ToString(), await Util.GetTokenAsync("BizAdminFull"));
|
||||||
|
Util.ValidateHTTPStatusCode(a, 204);
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach (long l in NotActiveWidgetIdList)
|
||||||
|
{
|
||||||
|
a = await Util.DeleteAsync("Widget/" + l.ToString(), await Util.GetTokenAsync("BizAdminFull"));
|
||||||
|
Util.ValidateHTTPStatusCode(a, 204);
|
||||||
|
}
|
||||||
|
|
||||||
|
//DELETE DATAFILTER
|
||||||
|
a = await Util.DeleteAsync("DataFilter/" + DataFilterId.ToString(), await Util.GetTokenAsync("BizAdminFull"));
|
||||||
|
Util.ValidateHTTPStatusCode(a, 204);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///////////////////////
|
///////////////////////
|
||||||
//BOOL
|
//BOOL
|
||||||
|
|||||||
Reference in New Issue
Block a user