sql >> Databasteknik >  >> NoSQL >> MongoDB

Hur testar man Mongo-index i integrationstester?

På våren

Med MongoTemplate#indexOps(String collection) du kan hämta en lista med IndexInfo , som representerar indexen för MongoDB-samlingen. Eftersom detta är en vanlig lista kan du göra dina påståenden med en kombination av hasItem(Matcher<? super T> itemMatcher) och hasProperty(String propertyName, Matcher<?> valueMatcher) :

final List<IndexInfo> indexes = mongoTemplate.indexOps("myCollection").getIndexInfo();
assertThat(indexes, hasSize(3));
assertThat(indexes, hasItem(hasProperty("name", is("_id_"))));
assertThat(indexes, hasItem(hasProperty("name", is("index1"))));
assertThat(indexes, hasItem(hasProperty("name", is("index2"))));
assertThat(indexes, hasItem(hasProperty("indexFields", hasItem(hasProperty("key", is("field1"))))));

Om du tycker att detta är för oläsligt eller obekvämt kan du ha det bättre med en anpassad Hamcrest-matchare.




  1. Mongoose gräns/offset och räkning fråga

  2. Webbskrapning med Scrapy och MongoDB

  3. Formatera datum i mongodb-frågeutdata på skalet

  4. Det går inte att skapa namnutrymme i transaktioner med flera dokument (MongoDB 4.0, Spring Data 2.1.0, Spring Boot)