Я получаю «внутреннюю ошибку сервера» (код состояния 500) при тестировании контроллера веб-API ASP.NET в in-memory test.Внутренняя ошибка сервера в тесте ASP.NET Web API in-memory
[TestFixture]
public class ValuesControllerTest
{
private HttpResponseMessage response;
[TestFixtureSetUp]
public void Given()
{
var config = new HttpConfiguration
{
IncludeErrorDetailPolicy = IncludeErrorDetailPolicy.Always
};
config.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{id}",
defaults: new { controller = typeof(ValuesController).Name.Replace("Controller", string.Empty), id = RouteParameter.Optional }
);
//This method will cause internal server error but NOT throw any exceptions
//Remove this call and the test will be green
ScanAssemblies();
var server = new HttpServer(config);
var client = new HttpClient(server);
response = client.GetAsync("http://something/api/values/5").Result;
//Here response has status code 500
}
private void ScanAssemblies()
{
PluginScanner.Scan(".\\", IsApiController);
}
private bool IsApiController(Type type)
{
return typeof (ApiController).IsAssignableFrom(type);
}
[Test]
public void Can_GET_api_values_5()
{
Assert.IsTrue(response.IsSuccessStatusCode);
}
}
public static class PluginScanner
{
public static IEnumerable<Type> Scan(string directoryToScan, Func<Type, bool> filter)
{
var result = new List<Type>();
var dir = new DirectoryInfo(directoryToScan);
if (!dir.Exists) return result;
foreach (var file in dir.EnumerateFiles("*.dll"))
{
result.AddRange(from type in Assembly.LoadFile(file.FullName).GetTypes()
where filter(type)
select type);
}
return result;
}
}
Я сконфигурировал Visual Studio для разрыва при получении какого-либо исключения .Net. Код не останавливается ни при каких обстоятельствах, и я не могу найти какие-либо детали исключения в ответе.
Что делать, чтобы узнать, что вызывает «внутреннюю ошибку сервера»?
Какова трассировка стека? Поместите это здесь. – Aliostad
Ну, в этом проблема. Я не получаю трассировку стека. Только ответ «Внутренняя ошибка сервера» –
означает, что означает '// дополнительная конфигурация'? Вы опустили какой-то код? – Aliostad