1

我正在使用 Mockito 在我的 JUnit 测试类中模拟一个类,如下所示:

@Before
public void initialize(){
    DescribeHiveTable mockObj = Mockito.mock(DescribeHiveTable.class);
    String tableName = "clslog_assessments";
    String parentDirectoryPath ="src/test/resources/TEST18/RunFiles";
    String[] mockFeaturesArray1 = {"user_id","event_id"};
    ArrayList<String> mockFeaturesList1 = new ArrayList<String> (Arrays.asList(mockFeaturesArray1));
    when(mockObj.describeTable(tableName, parentDirectoryPath)).thenReturn(mockFeaturesList1);

然后我有我的 Test 方法,该方法随后describeTable从内部调用该方法。我检查了参数:tableName以及parentDirectoryPath何时describeTable被调用与我在 initalize 方法中定义的参数相同。

但是,我仍然得到一个空返回值。我不明白这种行为。也许我没有正确使用 Mockito?

编辑

我的测试方法是这样的:

@Test
public void testComplexFeaturesExistingRun() {
String[] args = {masterConfigPath, runFilesPath, rootDir};
DriverClass driver = new DriverClass();
driver.main(args);
}

所以 driver.main 调用 describeTable 方法,我试图模拟它的行为。

编辑 2

我的描述蜂巢表类是:

public class DescribeHiveTable {

public ArrayList<String> describeTable(String tableName, String parentDirectoryPath){
    String hiveQuery = "'describe " + tableName + "';";
    String bashScriptFile = parentDirectoryPath + "/describeTable.sh";

    .
    .
    .
        final Process process = builder.start();
        InputStream is = process.getInputStream();
        InputStreamReader isr = new InputStreamReader(is);
        BufferedReader br = new BufferedReader(isr);
        String line;
        while((line=br.readLine())!=null) {
            String[] output = line.split("\t");
            columnList.add(output[0]);
       }
       return columnList;

这就是我调用描述表的方式:

DescribeHiveTable describeTable;
describeTable = new DescribeHiveTable();
ArrayList<String> columnList = describeTable.describeTable(tableName, runFile.getParent());
4

2 回答 2

2

使用 Mockito 的方法是

private DescribeHiveTable mockObj; // must be accessible to Test methods

@Before
public void initialize(){
    this.mockObj = Mockito.mock(DescribeHiveTable.class);
    <etc>
}

@Test
public void testComplexFeaturesExistingRun() {
    /* test the objects that are set up to use this.mockObj,
       and not the usual type of DescribeHiveTable */
}

注意

describeTable = new DescribeHiveTable();

表示您使用的是新的、未模拟的 ,DescribeHiveTable而不是模拟的mockObj.

但看起来您无法控制DescribeHiveTable? DriverClass如果是这样的话,那么要么

  • Mockito 不会帮助你——或者你至少也必须嘲笑它DriverClass​​;或者
  • 您必须使用反射将describeTableinDriverClass替换为mockObj.
于 2013-09-21T04:03:45.637 回答
1

DriverClass您可以使用模拟DescribeHiveTable(假设DescribeHiveTable是 的实例变量)初始化DriverClass,如下所示:

public class TestClass{

@Mock
DescribeHiveTable mockObj;
// This will create a new instance of DriverClass with a mock of DescribeHiveTable
@InjectMocks
DriverClass driver;

@Before
    public void init() {

        MockitoAnnotations.initMocks(this);

        tableName = "clslog_assessments";
        parentDirectoryPath = "src/test/resources/TEST18/RunFiles";
        mockFeaturesArray1 = new String[] { "user_id", "event_id" };
        mockFeaturesList1 = new ArrayList<String>(
                Arrays.asList(mockFeaturesArray1));
        when(mockObj.describeTable(tableName, parentDirectoryPath)).thenReturn(
                mockFeaturesList1);
}

@Test
public void test() {
    // when(methodCall)
    assertEquals(mockFeaturesList1, driver.main());
}

}
于 2013-09-21T05:06:50.843 回答