我有一个 json 负载,我想以一种不平凡的方式反序列化。
{
"destinationId": 123
}
目标类是
public class SomeObject
{
public Destination Destination { get; set; }
}
public class Destination
{
public Destination(int destinationId)
{
Id = destinationId;
}
public int Id { get; set; }
}
为了能够做到这一点,我创建了一个JsonConverter
就可以了。
这是 ReadJson 方法:
public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
{
if (CanConvert(objectType))
{
var value = reader.Value;
if (value is long v)
{
// TODO: this might overflow
return new Destination((int)v);
}
}
return null;
}
然后我用一个装饰 Destination 类[JsonConverter]
属性接受一个typeof(DestinationConverter)
.
当我使用时这可以正常工作JsonConvert.DeserializeObject<SomeObject>(myString)
(请参阅下面的单元测试)但我在为以下内容创建成功的单元测试时遇到问题JsonConverter
具体来说(参见下面的第二个测试)。
[Test, AutoData]
public void SomeObject_is_correctly_deserialized(SomeObject testObject)
{
var json = $@"{{""destinationId"":{testObject.Destination.Id}}}";
Console.WriteLine($"json: {json}");
var obj = JsonConvert.DeserializeObject<SomeObject>(json);
Assert.That(obj.Destination.Id, Is.EqualTo(testObject.Destination.Id));
}
[Test, AutoData]
public void ReadJson_can_deserialize_an_integer_as_Destination(DestinationConverter sut, int testValue)
{
JsonReader reader = new JTokenReader(JToken.Parse($"{testValue}"));
var obj = sut.ReadJson(reader, typeof(Destination), null, JsonSerializer.CreateDefault());
var result = obj as Destination;
Assert.That(result, Is.Not.Null);
Assert.That(result, Is.InstanceOf<Destination>());
Assert.That(result.Id, Is.EqualTo(testValue));
}
我一直在谷歌上搜索一种正确对转换后的单元进行测试的方法,但我只找到了人们使用整个DeserializeObject
而不仅仅是测试转换器。
PS:我将所有必要的代码粘贴到 .NET Fiddle 中:https://dotnetfiddle.net/oUXi6k https://dotnetfiddle.net/oUXi6k