を含む列で分割しようとしている dapper の MultiMaps に問題がありますNULL
。Dapper はオブジェクトをインスタンス化していないようで、私のマッピング関数はnull
オブジェクトの代わりに受け取ります。
これが私の新しいテストです:
class Product
{
public int Id { get; set; }
public string Name { get; set; }
public Category Category { get; set; }
}
class Category
{
public int Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
}
public void TestMultiMapWithSplitWithNullValue()
{
var sql = @"select 1 as id, 'abc' as name, NULL as description, 'def' as name";
var product = connection.Query<Product, Category, Product>(sql, (prod, cat) =>
{
prod.Category = cat;
return prod;
}, splitOn: "description").First();
// assertions
product.Id.IsEqualTo(1);
product.Name.IsEqualTo("abc");
product.Category.IsNotNull();
product.Category.Id.IsEqualTo(0);
product.Category.Name.IsEqualTo("def");
product.Category.Description.IsNull();
}
失敗する行は、マッピング関数に渡されproduct.Category.IsNotNull();
たという事実が原因です。cat
null
このメソッドを Assert クラスにも追加しました。
public static void IsNotNull(this object obj)
{
if (obj == null)
{
throw new ApplicationException("Expected not null");
}
}