Tengo el siguiente HttpModule que quería probar en la unidad. El problema es que no puedo cambiar los modificadores de acceso/estáticos ya que deben ser como están. Me preguntaba cuál sería el mejor método para probar el siguiente módulo. Todavía soy bastante nuevo en las pruebas y principalmente buscando consejos sobre la estrategia de prueba y en general probando HttpModules. Solo para aclararlo, solo intento capturar cada URL solicitada (solo páginas .aspx) y verificar si la URL solicitada tiene permiso (para usuarios específicos en nuestra Intranet). Hasta ahora, siento que realmente no puedo probar este módulo (desde una perspectiva productiva).ASP.NET + NUnit: buena estrategia de pruebas unitarias para HttpModule usando .NET 4
public class PageAccessPermissionCheckerModule : IHttpModule
{
[Inject]
public IIntranetSitemapProvider SitemapProvider { get; set; }
[Inject]
public IIntranetSitemapPermissionProvider PermissionProvider { get; set; }
public void Init(HttpApplication context)
{
context.PreRequestHandlerExecute += ValidatePage;
}
private void EnsureInjected()
{
if (PermissionProvider == null)
KernelContainer.Inject(this);
}
private void ValidatePage(object sender, EventArgs e)
{
EnsureInjected();
var context = HttpContext.Current ?? ((HttpApplication)sender).Context;
var pageExtension = VirtualPathUtility.GetExtension(context.Request.Url.AbsolutePath);
if (context.Session == null || pageExtension != ".aspx") return;
if (!UserHasPermission(context))
{
KernelContainer.Get<UrlProvider>().RedirectToPageDenied("Access denied: " + context.Request.Url);
}
}
private bool UserHasPermission(HttpContext context)
{
var permissionCode = FindPermissionCode(SitemapProvider.GetNodes(), context.Request.Url.PathAndQuery);
return PermissionProvider.UserHasPermission(permissionCode);
}
private static string FindPermissionCode(IEnumerable<SitemapNode> nodes, string requestedUrl)
{
var matchingNode = nodes.FirstOrDefault(x => ComparePaths(x.SiteURL, requestedUrl));
if (matchingNode != null)
return matchingNode.PermissionCode;
foreach(var node in nodes)
{
var code = FindPermissionCode(node.ChildNodes, requestedUrl);
if (!string.IsNullOrEmpty(code))
return code;
}
return null;
}
public void Dispose() { }
}
hm nadie más respondió por lo que se tómalo como respuesta por el momento e intenta separar mi lógica. Todavía estoy buscando una respuesta diferente por cierto (si la hay :)) – MSI