Как однократно запустить @DataJpaTest для реальной базы данных, а не в памяти с помощью Spring BootJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Как однократно запустить @DataJpaTest для реальной базы данных, а не в памяти с помощью Spring Boot

Сообщение Anonymous »

Я использую Spring Boot 1.4.3 и имею кучу тестов, помеченных @DataJpaTest. По умолчанию они работают с базой данных в памяти. Я хотел бы иметь возможность временно запускать их все на локальном MySQL. Как я могу это сделать простым способом?

Я обнаружил, что могу заставить его работать для одного, добавив @ActiveProfiles("local"), где у меня есть application-local.properties, который указывает на мой локальный MySQL, но добавлять его везде, запускать тесты и затем снова удалять (так как я хочу запустить это вручную только для MySQL, среда CI будет работать с внутренней памятью) db).

Я использую Maven, если это имеет значение.

ОБНОВЛЕНИЕ:

Итак, у меня есть application-local.properties, который содержит свойства базы данных для подключения к моей локальной базе данных MySQL (которую я уже использую для запуска своего приложения на локальном MySQL)

Затем я щелкаю правой кнопкой мыши в IntelliJ по пакету и выбираю «Выполнить все тесты в пакете». В настройках этой конфигурации запуска я добавляю -Dspring.profiles.active=local в поле «Параметры виртуальной машины».

Я думал, что это активирует локальный профиль во время тестов, но это не так. Если я остановлю локальный MySQL, тесты все равно пройдут нормально.

Подробнее здесь: https://stackoverflow.com/questions/416 ... emory-with
Ответить

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

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

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

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

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