Я пытаюсь настроить некоторые интеграционные тесты для приложения 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
Загрузка данных в базу данных в памяти с помощью Spring-test-dbunit ⇐ JAVA
Программисты JAVA общаются здесь
-
Anonymous
1717188527
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:
Подробнее здесь: [url]https://stackoverflow.com/questions/76971191/loading-data-into-an-in-memory-database-using-spring-test-dbunit[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия