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 System.ComponentModel.DataAnnotations.Schema;
using Sieve.Attributes; using Sieve.Attributes;
@ -14,6 +14,7 @@ namespace SieveTests.Entities
[Sieve(CanFilter = true, CanSort = true)] [Sieve(CanFilter = true, CanSort = true)]
public int LikeCount { get; set; } = new Random().Next(0, 1000); public int LikeCount { get; set; } = new Random().Next(0, 1000);
[Sieve(CanFilter = true, CanSort = true)] [Sieve(CanFilter = true, CanSort = true)]
public int CommentCount { get; set; } = new Random().Next(0, 1000); public int CommentCount { get; set; } = new Random().Next(0, 1000);
@ -23,5 +24,8 @@ namespace SieveTests.Entities
[Sieve(CanFilter = true, CanSort = true)] [Sieve(CanFilter = true, CanSort = true)]
[Column(TypeName = "datetime")] [Column(TypeName = "datetime")]
public DateTime DateLastViewed { get; set; } = DateTime.UtcNow; 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), CommentCount = table.Column<int>(nullable: false),
DateCreated = table.Column<DateTimeOffset>(nullable: false), DateCreated = table.Column<DateTimeOffset>(nullable: false),
LikeCount = table.Column<int>(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)); 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>("LikeCount");
b.Property<int?>("CategoryId");
b.Property<string>("Title"); b.Property<string>("Title");
b.HasKey("Id"); b.HasKey("Id");

View File

@ -19,6 +19,9 @@ namespace SieveUnitTests.Entities
[Sieve(CanFilter = true, CanSort = true)] [Sieve(CanFilter = true, CanSort = true)]
public DateTimeOffset DateCreated { get; set; } = DateTimeOffset.UtcNow; 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)] [Sieve(CanFilter = true, CanSort = true)]
public bool IsDraft { get; set; } public bool IsDraft { get; set; }

View File

@ -1,4 +1,4 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;
using Microsoft.VisualStudio.TestTools.UnitTesting; using Microsoft.VisualStudio.TestTools.UnitTesting;
@ -28,24 +28,28 @@ namespace SieveUnitTests
Id = 0, Id = 0,
Title = "A", Title = "A",
LikeCount = 100, LikeCount = 100,
IsDraft = true IsDraft = true,
CategoryId = null,
}, },
new Post() { new Post() {
Id = 1, Id = 1,
Title = "B", Title = "B",
LikeCount = 50, LikeCount = 50,
IsDraft = false IsDraft = false,
CategoryId = 1,
}, },
new Post() { new Post() {
Id = 2, Id = 2,
Title = "C", Title = "C",
LikeCount = 0 LikeCount = 0,
CategoryId = 1,
}, },
new Post() { new Post() {
Id = 3, Id = 3,
Title = "D", Title = "D",
LikeCount = 3, LikeCount = 3,
IsDraft = true IsDraft = true,
CategoryId = 2,
}, },
}.AsQueryable(); }.AsQueryable();
} }
@ -103,6 +107,19 @@ namespace SieveUnitTests
Assert.AreEqual(result.First().Id, 0); 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] [TestMethod]
public void EqualsDoesntFailWithNonStringTypes() public void EqualsDoesntFailWithNonStringTypes()
{ {