2

我有以下结构:

public class MyDao{

private JdbcTemplate  jdbcTemplate;
private DataSource dataSource;


public DataSource getDataSource() {
    return dataSource;
}


public void setDataSource(DataSource dataSource) {
    this.dataSource = dataSource;
}

public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }

    public VCASDao(DataSource dataSource ){
        jdbcTemplate = new JdbcTemplate(dataSource);
    }
}

一些经理类

 public class MyManager{

MyDao dao = null;
private DataSource dataSource;

public MyManager(){}

    public DataSource getDataSource() {
        return dataSource;
    }

    public void setDataSource(DataSource dataSource) {
        this.dataSource = dataSource;
    } 

   public void someMethod(Object o){
      dao.save(o);
   }
   }
}

和门面类

public class MyFacadeClass{

private MyManager manager;

public MyFacadeClass(){
 manager = new MyManager();
}

public void someFacadeMethod(Object o){
 manager.someMethod(o);
}

}

现在我想用 JUnit 和 Mockito 来测试它。我的问题是我没有 JNDI 架构,我需要使用基于 HSQLDB 的 DataSource 模拟 JdbcTemplate。

我的嘲笑是这样的:

@Mock
static BasicDataSource dataSource ;

@Mock
static JdbcTemplate jdbcTemplate ;

@Mock 
MyDao dao;

MyFacadeClass myFacadeClass = new MyFacadeClass();

    @BeforeClass
    public static void init(){
          dataSource = new BasicDataSource();
      dataSource.setDriverClassName("org.hsqldb.jdbcDriver");
          dataSource.setUrl("jdbc:hsqldb:mem:Test");
          dataSource.setUsername("sa");
          dataSource.setPassword("");
          dataSource.setInitialSize(5);
          dataSource.setMaxActive(10);
          dataSource.setPoolPreparedStatements(true);
          dataSource.setMaxOpenPreparedStatements(10);
          jdbcTemplate = new JdbcTemplate(dataSource);
          jdbcTemplate
          .execute("create Some Table");
    }


@Test
public void testSomeFacadeMethod(){
Object o = new Object();
myFacadeClass.someFacadeMethod(o);
}

我在 MyManager 构造函数中遇到异常,即“some_DB”的 JNDI 名称不存在。

我认为我对 Mocking 通用方法有疑问。请帮忙。

PS:我在这个项目中没有使用 spring,只是使用 JdbcTemplate 类来简化代码。

更新:

我改变了我的课程,但现在 dao 对象为空。

4

2 回答 2

5

根据您发布的内容,我收集到您想要测试MyFacadeClass。如果确实如此,那么您在这里嘲笑错误的东西。

唯一有趣的关系是MyFacadeClass-> MyManager。JNDI 和 JdbcTemplate 甚至不可见MyFacadeClass,你为什么要让它们出现在你的测试中;)

这是我要走的方向,同时保持相同的架构:

  1. 所以在MyFacadeClassTest你应该只模拟MyManager和注入它MyFacadeClass,并测试相关的场景。

  2. MyManager中,我建议你不要测试 JNDI 的东西,例如你可以创建一个包可见的构造函数,它直接接受一个MyDao对象。将这些 JNDI 内容外部化到另一个类中会更好,它可能类似于MyDaoProvider. 然后在MyManagerTest您将测试与MyManager模拟MyDao之间的相关交互。

  3. 最后,您需要进行测试MyDao,因为 DAO 只能使用真实数据库正确测试,这意味着它需要另一个系统才能运行。此测试是集成测试。您将针对真实数据库(Oracle 等)或内存数据库(HSQLDB 等)运行它,在这种情况下,您将根据您的测试环境创建一个真实的 JdbcTemplate,并将其注入 DAO . 此外,您根本无法运行这些测试,而是运行业务验收测试。

希望有帮助。

于 2012-06-14T13:03:13.103 回答
1

MyManager不应该查找数据源。应将数据源注入其中。这是Dependency Injection原则。它使测试更容易,因为您可以轻松地将自己的实现放入其中(在这种情况下是您自己的数据源)。

另一种选择是在类中添加一个getDataSource()方法MyManager,然后模拟它。

于 2012-06-14T12:02:35.393 回答