0

我正在使用 dbsetup 框架来设置我的数据库。我正在尝试使用 annotation 测试存储库级别(我正在使用 Spring 数据)@DataJpaTest。要使用“dbsetup”设置数据库,我需要自动连接数据源,但我无法自动连接,因为@DataJpaTest创建了自己的数据源并且数据源已经存在(但我不知道如何使用它......)。问题是如何自动连接数据源来设置我的数据库@DataJpaTest

@RunWith(SpringRunner.class)
@DataJpaTest
@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)
@TestPropertySource("/application-test.properties")
public class ArticleRepositoryTest {

    @Autowired
    private ApplicationContext applicationContext;
    @Autowired
    private EntityManager entityManager;
    @Autowired
    private ArticleRepository articleRepository;
    @Autowired
    private TagRepository tagRepository;
    @Autowired
    private UserRepository userRepository;
    //here is the error, because datasource already exists...
    @Autowired
    private DataSource dataSource;

    @Before
    public void cleanData() throws SQLException {
        Operation operation = sequenceOf(CommonOperations.DELETE_ALL);
        DbSetup dbSetup = new DbSetup(new DataSourceDestination(dataSource), operation);
        dbSetup.launch();

        DBUtil.resetAutoIncrementColumns(applicationContext, "article", "tag", "user");
    }
4

1 回答 1

0

如果您不需要自动配置的数据库,请删除 @DataJpaTest,@AutoConfigureTestDatabase 会根据您在 application-test.properties 中配置的数据库创建数据源。

于 2018-07-26T16:46:43.550 回答