如何模拟CellSet对象

时间:2016-04-20 09:19:06

标签: c# unit-testing adomd.net

我有一个将CellSet转换为DataTable的方法。像这样:

public DataTable ConvertCellSetToDataTable(CellSet cellSet)
{
    if (cellSet == null)
    {
        return null;
    }

    var dataTable = new DataTable();
    SetColumns(cellSet, dataTable);
    WriteValues(cellSet, dataTable);
    return dataTable;
}

现在我想为这个方法编写单元测试。通常我会使用new来创建一个实例,但这次我没有看到这个类的任何公共构造方法。

那么,无论如何我可以

  1. 模拟一个CellSet对象
  2. 并修改它的属性,例如Axes?
  3. Rhino.Mocks是我对单元测试框架的选择。

1 个答案:

答案 0 :(得分:1)

你不应该模仿你不拥有的类/对象。在这种情况下,因为您将方法耦合到CellSet,所以您现在直接依赖于它。

Microsoft.AnalysisServices.AdomdClient命名空间中的大多数类都是密封的,并且不提供任何公共构造函数,这使得它们很难模拟/伪造。

查看CellSet类并确定您希望从中获得哪些功能。提取您需要的属性/方法,并决定您要控制的服务背后的内容。

以下是我刚才解释的简化示例。

public class MyClassUnderTest {
    public DataTable ConvertCellSetToDataTable(ICellSetWrapper cellSet) {
        if (cellSet == null) {
            return null;
        }

        var dataTable = new DataTable();
        SetColumns(cellSet, dataTable);
        WriteValues(cellSet, dataTable);
        return dataTable;
    }

    private void WriteValues(ICellSetWrapper cellSet, DataTable dataTable) {
        //...assign value to datarows
    }

    private void SetColumns(ICellSetWrapper cellSet, DataTable dataTable) {
        //...read data from this CellSet and build data columns
    }
}

public interface ICellSetWrapper {
    //...Methods and propeties exposing what you want to use
}

public class MyCellSetWrapper : ICellSetWrapper {
    CellSet cellSet;
    public MyCellSetWrapper(CellSet cellSet) {
        this.cellSet = cellSet;
    }
    //...Implemented methods/properties
}

然后,您可以模拟所需的功能,以便使用您选择的测试框架测试您的方法。