繁体   English   中英

如何使用 jUnit 测试 JdbcTemplate 方法?

[英]How test JdbcTemplate methods using jUnit?

我使用 Spring 和 JdbcTemplate 编写了简单的 java 项目。 我写了 SpringConfig class 我在其中放置了我的 Postgres 数据库信息并创建了 DataSource 和 JdbcTemplate bean。 然后我用 Autowired class 构造函数编写了 CRUD 方法,一切运行正常,但测试没有。 I want to use H2 database and create application.properties in test.resources package, then I create test class where I create class constructor and also Autowire it, and when am trying to test CRUD methods I get ParameterResolutionException: "failed to resolve parameter [ javax.sql.DataSource arg0] 在构造函数中”。 你能证明我的错误吗:

@Configuration
public class SpringConfig {

private static final String URL = "jdbc:postgresql://localhost:5432/test";
private static final String DRIVER = "org.postgresql.Driver";
private static final String USERNAME = "root";
private static final String PASSWORD = "123";

@Bean
public DataSource dataSource() {

    DriverManagerDataSource dataSource = new DriverManagerDataSource();
    dataSource.setDriverClassName(DRIVER);
    dataSource.setUrl(URL);
    dataSource.setUsername(USERNAME);
    dataSource.setPassword(PASSWORD);
    return dataSource;
}
@Bean
public JdbcTemplate jdbcTemplate(){
    return new JdbcTemplate(dataSource());
}
@Repository
public interface SimpleDao<E> {

void create(E e);

Optional<E> read(int id);

void delete(E e);

void update(E e);

List<E> index();
}
public interface StudentDao extends SimpleDao<Student> {
}
@Component
public class SpringStudentDao implements StudentDao {
private static Logger logger = LoggerFactory.getLogger(SpringStudentDao.class);

private final JdbcTemplate jdbcTemplate;

public SpringStudentDao(JdbcTemplate jdbcTemplate) {
    this.jdbcTemplate = jdbcTemplate;
}

@Override
public void create(Student student) {
    String sql = "INSERT INTO student VALUES(?,?,?)";
    int insert = jdbcTemplate.update(sql, student.getID(), student.getName(), student.getSurname());
    if (insert == 1) {
        logger.info("New student added " + student.toString());
    }
}

@Override
public Optional<Student> read(int id) {
    String sql = "SELECT * FROM student WHERE id=?";
    Student student = null;
    try {
        student = jdbcTemplate.queryForObject(sql, new Object[]{id}, new StudentMapper());
    } catch (DataAccessException exception) {
        logger.info("Student not found " + id);
    }
    return Optional.ofNullable(student);
}

@Override
public List<Student> index() {
    String sql = "SELECT * FROM student";
    return jdbcTemplate.query(sql, new StudentMapper());
}
@DataJdbcTest
class SpringStudentDaoTest {

private JdbcTemplate jdbcTemplate;
private SpringStudentDao studentDao;


@Autowired
public SpringStudentDaoTest(DataSource dataSource){
    jdbcTemplate = new JdbcTemplate(dataSource);
    studentDao = new SpringStudentDao(jdbcTemplate);

}

@Test
public void shouldGetListOfStudents(){
    List<Student> students = studentDao.index();
    assertEquals(4, students.size());
}

为什么您尝试为您的嵌入式数据库构建 JdbcTemplate 而不是自动配置它?

@DataJdbcTest
public class JdbcTest {

    JdbcTemplate jdbcTemplate;

    @Autowired
    JdbcTest(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }

    @Test
    public void myTest() {
    }

}

自动配置数据 JDBC 测试中检查@DataJdbcTest的信息

默认情况下,它配置一个内存嵌入式数据库、一个 JdbcTemplate 和 Spring 数据 JDBC 存储库。 常规 @Component bean 不会加载到 ApplicationContext 中。

@DataJdbcTest 自动配置的组件的完整列表 - 请参阅附录 D。测试自动配置注释

org.springframework.boot.autoconfigure.cache.CacheAutoConfiguration org.springframework.boot.autoconfigure.data.jdbc.JdbcRepositoriesAutoConfiguration org.springframework.boot.autoconfigure.flyway.FlywayAutoConfiguration org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration org.springframework. boot.autoconfigure.jdbc.DataSourceTransactionManagerAutoConfiguration org.springframework.boot.autoconfigure.jdbc.JdbcTemplateAutoConfiguration org.springframework.boot.autoconfigure.liquibase.LiquibaseAutoConfiguration org.springframework.boot.autoconfigure.transaction.TransactionAutoConfiguration org.springframework.boot.test.autoconfigure. jdbc.TestDatabaseAutoConfiguration

为什么你的方法失败了:

  • 如上所述,不会扫描您的配置 class。 您可以明确启用它 - 检测测试配置

如果您熟悉 Spring 测试框架,您可能习惯于使用 @ContextConfiguration(classes=...) 来指定要加载哪个 Spring @Configuration。 或者,您可能经常在测试中使用嵌套的 @Configuration 类。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM