java - 如何在测试类中模拟 JNDI 数据源

标签 java spring unit-testing mocking mockito

我正在尝试测试我的 DAO 类,它有 2 个依赖项:dataSourcestringCrypto 但应用程序不断抛出

Failed to obtain JDBC Connection: DataSource returned null from getConnection(): dataSource

我试图模拟的数据源依赖项是一个使用JndiDataSourceLookUp的bean 这是

@Bean
public DataSource dataSource() {
    JndiDataSourceLookup dataSourceLookup = new JndiDataSourceLookup();

    dataSourceLookup.setResourceRef(true);

    DataSource dataSource = dataSourceLookup.getDataSource("castle/db");

    return dataSource;
}

这是 DAO 类

public class PersonDAOImpl implements PersonDAO {

@Autowired
private DataSource dataSource;

@Autowired
private Cryptography stringCrypto;

private NamedParameterJdbcTemplate namedParameterJdbcTemplate;

@Override
public List<Member> getAllMembers() {

    this.namedParameterJdbcTemplate = new NamedParameterJdbcTemplate(dataSource);

    try {
        List<Member> members = namedParameterJdbcTemplate.query(SqlStatement.GET_ALL_MEMBERS,
                new MemberExtractor());

        return members;
    } catch (Exception e) {
        e.printStackTrace();
        return null;

    }

}

正如您在此类中看到的,它有 2 个依赖项,我试图在下面的测试类中模拟它们

@RunWith(SpringRunner.class)
public class MembersControllerTest {

@Mock
DataSource dataSource;

@Mock
Cryptography stringCrypto;

@InjectMocks
PersonDAOImpl personDAOImpl;

@BeforeEach
void setUp() {
    MockitoAnnotations.initMocks(this);
}

@Test
public void test() {

    assertTrue(personDAOImpl.getAllMembers().size() > 0);

}

}

我尝试添加

@PostConstruct
private void initialization() {
    this.namedParameterJdbcTemplate = new NamedParameterJdbcTemplate(dataSource);
}

但它不起作用,每当我运行测试时,它都会抛出 failed to acquire jdbc connection 。 抛出的异常根本没有帮助,所有其他类似的问题都是关于使用 xml 进行配置,并且接受的答案是建议一些 xml 配置,老实说,我不太理解,我什至不想在我的应用程序中使用 xml应用。 我确实搜索了几乎所有相关问题,但没有发现任何有帮助的,所以我决定问它。

提前致谢

最佳答案

您仅模拟 DataSource,因此 NamedParameterJdbcTemplate 仍然会调用 getConnection() 来获取连接并执行查询。推荐的方法是将 NamedParameterJdbcTemplate 声明为 spring bean,然后需要模拟它

配置类

@Bean
public DataSource dataSource() {
  JndiDataSourceLookup dataSourceLookup = new JndiDataSourceLookup();

  dataSourceLookup.setResourceRef(true);

  DataSource dataSource = dataSourceLookup.getDataSource("castle/db");

  return dataSource;
}

 @Bean
 public NamedParameterJdbcTemplate namedParameterJdbcTemplate(DataSource dataSource) {
   return new NamedParameterJdbcTemplate(dataSource);

}

测试类

 @RunWith(SpringRunner.class)
 public class MembersControllerTest {

     @Mock
     DataSource dataSource;

     @Mock
     Cryptography stringCrypto;

     @Mock
     NamedParameterJdbcTemplate namedParameterJdbcTemplate;

     @InjectMocks
     PersonDAOImpl personDAOImpl;

     @BeforeEach
     void setUp() {
         MockitoAnnotations.initMocks(this);
     }

  @Test
  public void test() {

    when(namedParameterJdbcTemplate.query(ArgumentMatchers.anyString(),
                                          ArgumentMatchers.any(MemberExtractor.class))
                                         .thenReturn(//List<Members>);
    assertTrue(personDAOImpl.getAllMembers().size() > 0);

     }

 }

关于java - 如何在测试类中模拟 JNDI 数据源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58002716/

相关文章:

Java mailto 到 MIME

java - Spring mvc jackson json 映射器-如何将 unicode 编码应用于 json 响应中的特殊字符

java - spring上传文件问题

java - 使用 Autowiring 组件为 Spring Boot 服务应用程序编写 JUnit 测试用例

c++ - 如何对控制台输入类进行单元测试?

java.lang.IllegalArgumentException : No enum const class 异常

java - 在改造库中禁用 SSL 证书检查

java - 需要帮助让我的 Java UDP 客户端应用程序正常工作

.net - 如何在 .net MVC 3 中使用角色测试授权属性?

python - 如何在 python 中对工厂进行单元测试?