MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Как да тествам Mongo индекси в интеграционни тестове?

През пролетта

С MongoTemplate#indexOps(String collection) можете да извлечете списък с IndexInfo , представляващи индексите на колекцията MongoDB. Тъй като това е обикновен списък, можете да правите вашите твърдения с комбинация от hasItem(Matcher<? super T> itemMatcher) и 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"))))));

Ако смятате, че това е твърде нечетливо или неудобно, може да е по-добре с персонализиран съпоставител на Hamcrest.




  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Актуализиране на елемент от масив в mongo

  2. Заявки в Postgres JSON масиви

  3. MongoDB Capped Collection не премахва документи

  4. Увеличаване на производителността чрез използване на групови вмъквания срещу обикновени вмъквания в MongoDB

  5. Кеширане на обект на колекция Mongodb в Node.js