单元测试WebForm的UI逻辑及文件上传

发表于:2013-1-28 10:01

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:陆敏技    来源:51Testing软件测试网采编

  BS系统中的UI部分的逻辑测试,最首要的就是要模拟请求(Request)和输出(Response),而WebForm又跟MVC不一样,后者的Response,Request等HTTP上下文对象均有接口支持,很容易模拟,而查看WebForm的对应对象,如Response,我们首先看到的声明就是:

public sealed class HttpResponse

  无接口,并且是sealed,换句话说,我们要测试一个如下的的Code-Behind函数的逻辑正确性,该怎么测试:

protected void Page_Load(object sender, EvengArgs e)
{
  this.Response.Write("test u");
}

  好在FCL中有现成的包装类HttpResponseWrapper来解决我们的烦恼(不然得自己写包装类),我们将上面的代码改成如下的形式,它就可以变得可测试:

protected HttpResponseBase _response;

protected override void OnPreLoad(EventArgs e)
{
  base.OnPreLoad(e);
  _response = new HttpResponseWrapper(this.Response);
}

protected void Page_Load(object sender, EvengArgs e)
{
  _response.Write("test u");
}

  上面的重构,并不影响原有功能的实现,同时却将代码修改成可测试的,

  1:首先,this.Response被替代成可以被模拟的HttpResponseBase;

  2:其次,方法Page_Load内部不再负责生成被依赖的对象的生成;

  即,我们将_response的生成放到方法的外部。这个外部,可以是构造器等,不过由于webform本身的特殊性,在构造器中,this.Response上下文还不可用,所以在这个例子中放到了OnPreLoad中。

  接下来看看测试类的编写,先说点额外话,Page_Load是protected的,要让测试类可以访问到它,需改成public或者干脆让测试类继承我们的当前页面,这里采用的是后者:

[TestClass]
public class _DefaultTest: _Default        ////很明显,这里测试的是Default.aspx.cs这个类
{
  public Mock<HttpResponseBase> FakeResponse;

  [TestMethod]
  public void LoadOk()
  {
FakeResponse = new Mock<HttpResponse>();

StringWriter sw = new StringWriter();
FakeResponse.SetupGet(x=>x.OutPut).Returns(sw);
this._response = FakeResponse.Object;

FakeResponse.Setup(x=>x.Write(It.IsAny<string>())).CallBack<string((x)=>
{
  sw.Write(x);
  sw.Flush();
}

this.Page_Load(null,null);
Assert.AreEqual(
  “test u”,
  (FakeResponse.Object.Output as StringWriter).ToString();
  }
}

21/212>
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号