我有extended the JsonMediaTypeFormatter
,以便在JSON中为decorated with a custom attribute类型生成“根”对象。
我如何对这个格式化程序进行单元测试?我对如何检查WriteToStreamAsync(..)
方法特别感兴趣。
答案 0 :(得分:3)
免费的O'Reilly电子书Designing Evolvable Web APIs with ASP.NET在how to test a MediaTypeFormatter
上有一些非常有用的具体建议。
以下是WriteToStreamAsync
的测试方法。 (这是我对test WebApiContrib.Formatters.Xlsx采取的方法,效果很好。)
var ms = new MemoryStream();
var content = new FakeContent();
content.Headers.ContentType = new MediaTypeHeaderValue("application/atom+xml");
var formatter = new SyndicationMediaTypeFormatter();
var task = formatter.WriteToStreamAsync(typeof(List<ItemToSerialize>),
new List<ItemToSerialize> { new ItemToSerialize { ItemName = "Test" }},
ms,
content,
new FakeTransport()
);
task.Wait();
ms.Seek(0, SeekOrigin.Begin);
var atomFormatter = new Atom10FeedFormatter();
atomFormatter.ReadFrom(XmlReader.Create(ms));
Assert.Equal(1, atomFormatter.Feed.Items.Count());
注意事项:
FakeContent
和FakeTransport
分别是HttpContent
和TransportContext
类的假货,您可以在文章中找到这些代码。Task.Wait
用于阻止执行,直到WriteToStreamAsync
返回的任务完成。MemoryStream
,然后可以通过合适的格式化程序/解串器进行读取和解析,以便您可以进行测试断言。或者,您可以编写一个示例控制器实现,启动它运行并使用客户端测试来调用控制器方法。这就是Chris Missal在WebApiContrib.Formatting.Bson中所做的。
控制器不需要复杂:
public class TestController : ApiController
{
public Item Get(int id)
{
return new Item { ID = id };
}
// ...
}
设置服务器和客户端:
[TestFixtureSetUp]
public void fixture_init()
{
var config = new HttpConfiguration();
config.Formatters.Add(new TestMediaTypeFormatter());
config.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "{controller}/{id}",
defaults: new {id = RouteParameter.Optional}
);
var server = new HttpServer(config);
_client = new HttpClient(server);
_client.BaseAddress = new Uri("http://www.test.com/");
_client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/bson"));
}
现在,在您的测试中,调用客户端上的方法并使用结果执行您想要的操作:
var response = _client.GetAsync("test/1").Result;
var result = response.Content.ReadAsAsync<Item>(new HashSet<MediaTypeFormatter> {new TestMediaTypeFormatter()}).Result;