Загрузка данных в базу данных в памяти с помощью Spring-test-dbunitJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Загрузка данных в базу данных в памяти с помощью Spring-test-dbunit

Сообщение Anonymous »

Я пытаюсь настроить некоторые интеграционные тесты для приложения Java Spring. Я следовал инструкциям (https://github.com/ppodgorsek/spring-test-dbunit), но, похоже, ничего не работает. Я могу убедиться, что таблицы создаются и проверка схемы проходит. Однако когда я на самом деле запрашиваю источник данных в своих тестах, я получаю такие ошибки, как:

java.lang.IllegalArgumentException: невозможно загрузить набор данных из
"data.xml" с использованием класса
com.github.springtestdbunit.dataset.FlatXmlDataSetLoader

Похоже, что мой файл data.xml находится в неправильное местоположение, но я не понимаю, где оно должно быть. Я попытался добавить тот же пакет, что и тестовый класс (src/test/java/integration), но получил те же результаты. Я не совсем понимаю, что делаю неправильно. Может ли кто-нибудь подсказать?
Мой тестовый класс выглядит так:
@SpringJUnitConfig
@ContextConfiguration
@TestExecutionListeners({ DependencyInjectionTestExecutionListener.class,
DbUnitTestExecutionListener.class })
@SpringBootTest
@DatabaseSetup("data.xml")
@DatabaseTearDown("data.xml")
public class SubscriptionQueryTest{

@Autowired
private LearnerSubscriptionRepository learnerSubscriptionRepository;

@Test
public void testSubscriptionQuery()
{
assertNotNull(learnerSubscriptionRepository);
}

@Test
public void testFindDistinctEmails()
{
long lCount = learnerSubscriptionRepository.count();
assertTrue(lCount > 0);
ArrayList learnerEmails = learnerSubscriptionRepository.findDistinctMails();
assertNotNull(learnerEmails);
assertEquals(6, learnerEmails.size());
List found = new ArrayList();
//check that all the results are unique values
for (String email : learnerEmails ) {
assertFalse(found.contains(email));
found.add(email);
}
}
}

Он выполняет запросы к CrudRepository, который выглядит следующим образом:
public interface LearnerSubscriptionRepository extends CrudRepository {
@Query("SELECT DISTINCT mail FROM LearnerSubscription")
ArrayList findDistinctMails();
}

с классом сущности:
@Entity
public class LearnerSubscription {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "id", length = 100, nullable = false, unique = true)
private int id;

@Column(name = "sub", length = 100, nullable = false, unique = false)
private String sub;

@Column(name = "mail", length = 100, nullable = false, unique = false)
private String mail;
...
}

В каталоге src/test/resources у меня есть файлы application.properties:
jdbc.driverClassName=org.h2.Driver
spring.datasource.url=jdbc:h2:mem:myDb;mode=mysql;DB_CLOSE_DELAY=-1;NON_KEYWORDS=KEY,VALUE
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.H2Dialect
spring.jpa.hibernate.ddl-auto=validate
spring.jpa.show-sql=true
spring.jpa.hibernate.use-new-id-generator-mappings=false

и файл data.xml:











Подробнее здесь: https://stackoverflow.com/questions/769 ... est-dbunit
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»