Как предполагается построить некоторые тесты с использованием метода репозитория Spring Data MongoDB? Я хотел бы установить тестовую базу данных для своих тестов, так как я не хочу использовать производственную базу данных для этой цели. Это должно быть возможно, но я понятия не имею. Это мой контекст приложения:Весенние данные MongoDB: Модульные тесты с репозиториями
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mongo="http://www.springframework.org/schema/data/mongo"
xmlns:neo4j="http://www.springframework.org/schema/data/neo4j"
xsi:schemaLocation=
"http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/data/mongo
http://www.springframework.org/schema/data/mongo/spring-mongo-1.0.xsd
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/data/neo4j
http://www.springframework.org/schema/data/neo4j/spring-neo4j.xsd">
<!-- Default bean name is 'mongo' -->
<mongo:mongo host="${mongo.host}" port="${mongo.port}">
<mongo:options connections-per-host="8"
threads-allowed-to-block-for-connection-multiplier="4"
connect-timeout="${mongo.connect-timeout}"
max-wait-time="${mongo.max-wait-time}"
auto-connect-retry="true"
socket-keep-alive="true"
socket-timeout="${mongo.socket-timeout}"
slave-ok="true"
write-number="1"
write-timeout="0"
write-fsync="true"/>
</mongo:mongo>
<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
<constructor-arg ref="mongo" />
<constructor-arg name="databaseName" value="${mongo.db}" />
</bean>
<context:component-scan base-package="domain.company.group.project.data.repositories"/>
<!-- MongoDB repositories -->
<mongo:repositories base-package="domain.company.group.project.data.repositories.mongodb"/>
<!-- some other stuff -->
</beans>
И скажем, у меня есть простой репозиторий следующим образом:
public interface LocationRepository extends MongoRepository<Location, String>, LocationRepositoryCustom {
}
где LocationRepositoryImpl класс реализует все свои собственные методы для определенного места (объекта домена) класс , Мой тестовый класс выглядит следующим образом:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"/test-context.xml"})
public class LocationRepositoryTest {
@Autowired
private LocationRepository locationRepository;
/* Some tests... */
}
Я попытался вставить экземпляр MongoDB в моих эксплуатационных испытаниях (как описано here), но он не работает: соединение с тестовой базой данных установлено, но шаблон Монго, кажется, не который может быть перезаписан, поскольку все методы сохранения продолжают вставлять данные в базу данных «production».
Я использую Spring 3.2.0 и Spring Data Mongo 1.1.0.RELEASE. Я использую Junit для тестирования.
Любые предложения?
Заранее спасибо.
Эй, Мигель, спасибо за головы! В конце я фактически использовал разные контексты как для производственных, так и для тестовых сред, которые, как я заметил, по-видимому, это путь. В любом случае спасибо за ваш ответ, я обязательно посмотрю на Fongo! Hasta otra ;-) – jarandaf
Я хотел бы упомянуть об этой библиотеке, которую я только что нашел, которая выглядит просто потрясающе: https://github.com/lordofthejars/nosql-unit/ – jarandaf
Выглядит очень интересно @jaranda, спасибо за обмен! –