Set up Nullable Test

This commit is contained in:
Matt Furden 2018-05-27 18:32:21 -07:00
parent 930f86da01
commit 26d9b09bf7
5 changed files with 35 additions and 8 deletions

View File

@ -1,4 +1,4 @@
using System;
using System;
using System.ComponentModel.DataAnnotations.Schema;
using Sieve.Attributes;
@ -14,6 +14,7 @@ namespace SieveTests.Entities
[Sieve(CanFilter = true, CanSort = true)]
public int LikeCount { get; set; } = new Random().Next(0, 1000);
[Sieve(CanFilter = true, CanSort = true)]
public int CommentCount { get; set; } = new Random().Next(0, 1000);
@ -23,5 +24,8 @@ namespace SieveTests.Entities
[Sieve(CanFilter = true, CanSort = true)]
[Column(TypeName = "datetime")]
public DateTime DateLastViewed { get; set; } = DateTime.UtcNow;
[Sieve(CanFilter = true, CanSort = true)]
public int? CategoryId { get; set; } = new Random().Next(0, 4);
}
}

View File

@ -17,7 +17,8 @@ namespace SieveTests.Migrations
CommentCount = table.Column<int>(nullable: false),
DateCreated = table.Column<DateTimeOffset>(nullable: false),
LikeCount = table.Column<int>(nullable: false),
Title = table.Column<string>(nullable: true)
Title = table.Column<string>(nullable: true),
CategoryId = table.Column<int>(nullable: true)
},
constraints: table => table.PrimaryKey("PK_Posts", x => x.Id));
}

View File

@ -34,6 +34,8 @@ namespace SieveTests.Migrations
b.Property<int>("LikeCount");
b.Property<int?>("CategoryId");
b.Property<string>("Title");
b.HasKey("Id");

View File

@ -19,6 +19,9 @@ namespace SieveUnitTests.Entities
[Sieve(CanFilter = true, CanSort = true)]
public DateTimeOffset DateCreated { get; set; } = DateTimeOffset.UtcNow;
[Sieve(CanFilter = true, CanSort = true)]
public int? CategoryId { get; set; } = new Random().Next(0, 4);
[Sieve(CanFilter = true, CanSort = true)]
public bool IsDraft { get; set; }

View File

@ -1,4 +1,4 @@
using System;
using System;
using System.Collections.Generic;
using System.Linq;
using Microsoft.VisualStudio.TestTools.UnitTesting;
@ -28,24 +28,28 @@ namespace SieveUnitTests
Id = 0,
Title = "A",
LikeCount = 100,
IsDraft = true
IsDraft = true,
CategoryId = null,
},
new Post() {
Id = 1,
Title = "B",
LikeCount = 50,
IsDraft = false
IsDraft = false,
CategoryId = 1,
},
new Post() {
Id = 2,
Title = "C",
LikeCount = 0
LikeCount = 0,
CategoryId = 1,
},
new Post() {
Id = 3,
Title = "D",
LikeCount = 3,
IsDraft = true
IsDraft = true,
CategoryId = 2,
},
}.AsQueryable();
}
@ -103,6 +107,19 @@ namespace SieveUnitTests
Assert.AreEqual(result.First().Id, 0);
}
[TestMethod]
public void CanFilterNullableInts()
{
var model = new SieveModel()
{
Filters = "CategoryId==1"
};
var result = _processor.Apply(model, _posts);
Assert.IsTrue(result.Count() == 2);
}
[TestMethod]
public void EqualsDoesntFailWithNonStringTypes()
{
@ -174,4 +191,4 @@ namespace SieveUnitTests
Assert.AreEqual(3, entry.Id);
}
}
}
}