欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ASP.NET 2.0下的条件编译

程序员文章站 2023-01-10 14:06:52
在web开发中测试单个页面的功能实在是太麻烦,从首页用户名、密码进去后,经过一些操作后才可以来到你要测试的那个页面。(其实无论做什么的开发,测试单个功能都是很麻烦)。抱着小...

在web开发中测试单个页面的功能实在是太麻烦,从首页用户名、密码进去后,经过一些操作后才可以来到你要测试的那个页面。(其实无论做什么的开发,测试单个功能都是很麻烦)。抱着小心谨慎的态度,我一般喜欢写几段测一次,如果每次都兴师动众的启动整个项目来测试显然是很不经济的做法。

我一般会在solution中新增一个用于测试用的配置,在其中增加一个“test"之类的编译指令,然后在代码中,把一些测试条件,测试方法放到这个指令下。在开发团队还没有引进单元测试之类的概念的时候,我可不想用新增一个测试项目这样的方法来做这种事情。而且对于象web下单个的page这样的情况我也不知道应该是如何进行法。所以还是用以前自己的编译指令这种方法比较的轻车熟路点。

(我以前在写一些非web下的东西的时候,也喜欢把测试方法与类本身写在一个文件里,然后用编译指令区分开,如果要测试,就直接在开发环境下选择"test"的那个配置,然后启动testdriven来测试之,不用启动整个项目对机器省力多了,testdriven这个东西很管用的。
如果你是用c#作开发的,在开发环境中,如果当前这个编译条件不满足的时候,那些代码都会灰掉,而且可以缩进,一点都不障眼)

 

不过我的那些伎俩,在vs2005下有点不管用了,现在web开发跟以前有点区别了。在上面找来找去都找不到地方来新增编译指令,非web的开发还是可以找到地方新增的。折腾了半天,发现现在把一些设置的东西都放到web.config里来了,条件编译当然也不例外。

比如现在要加一个”test”的条件编译指令。在web.config文件中,在<compilation>这个节下加入下述语句就可以了。

      <compilers>

        <compiler language="vb"

              type="microsoft.visualbasic.vbcodeprovider, system, version=2.0.0.0, culture=neutral, publickeytoken=b77a5c561934e089"

              extension=".vb"

              compileroptions="/define:debug=true /define:trace=true /define:test=true "/>

        <compiler language="c#"

            type="microsoft.csharp.csharpcodeprovider, system, version=2.0.0.0, culture=neutral, publickeytoken=b77a5c561934e089"

            extension=".cs"

            compileroptions="/d:debug;trace;test"/>

      </compilers>

 

很要命的,对每一种语言都要加一个<compiler>,当然如果项目中没用到相应语言,也可以不用理它,可以删掉。一般c#、vb用得比较的多,我只搞了这二种。

web.config里设置过后就不用在每一个需测试的页面上去定义编译指令了,不过还是没有以前爽,以前直接在ide工具栏上选择一下配置就行了,现在硬是要写这么多东西,而且主要还是不方便切换。比如我不要在"test"条件下启动时,我还得跑到web.config里把上面一段东西注释掉。
按照msdn的说法,在.net 2.0下,<compiler>这个element是deprecated的了,我这种做法好象不是正路。