加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

桩破除依赖7-克服封装问题

发布时间:2020-12-14 01:36:30 所属栏目:百科 来源:网络整理
导读:克服封装问题 代码地址:http://git.oschina.net/zhv/UnitTest 使用internal和[InternalsVisibleTo] 如果不喜欢在类里添加人人可见的公共构造函数,就可以把它标记为internal而不是public。然后可以使用组件层级(assembly-level)的属性[InternalsVisibleTo]

克服封装问题

代码地址:http://git.oschina.net/zhv/UnitTest

使用internal和[InternalsVisibleTo]

如果不喜欢在类里添加人人可见的公共构造函数,就可以把它标记为internal而不是public。然后可以使用组件层级(assembly-level)的属性[InternalsVisibleTo]使所有internal的成员对测试程序集可见

以下是代码:

public class LogAnalyzer{
    ...
    internal LogAnalyzer(IExtensionManager extensionManager){
        manager = extensionMgr;
    }
    ...
}
using System.Runtime.CompilerServices;
[assembly:InternalsVisibleTo("AOUT.Chapter3.Logan.Tests")]

使用[Conditional]属性

如果有些方法只在某些调试模式下使用,就可以使用这个属性进行标记(构造函数除外)

[Conditional(“DEBUG")]
public void DoSomething(){
}

使用#if和#endif进行条件编译

把方法和专门供测试使用的构造函数放在#if和#endif结构里,可以确保他们只在相应的编译参数设置时编译,如下代码:

#if DEBUG
    public LogAnalyzer(IExtensionManager extensionmgr){
        manager = extensionMgr;
    }
#endif
...
#if DEBUG
    [Test]
    public void IsValidFileName_SupportedExtension_True(){
        //创建analyzer并注入
        LogAnalyzer log = new LogAnalyzer(myFakeManager);
        ...
    }
#endif

这种方法用的比较多,但和[Conditional]一样,会使代码看起来很杂乱。为保持代码清晰,在合适的时候考虑使用[InternalsVisibleTo]属性。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读