sql >> Database teknologi >  >> NoSQL >> MongoDB

Hvordan tester man Mongo-indekser i integrationstest?

I foråret

Med MongoTemplate#indexOps(String collection) du kan hente en liste over IndexInfo , der repræsenterer indekserne for MongoDB-samlingen. Da dette er en almindelig liste, kan du gøre dine påstande med en kombination af hasItem(Matcher<? super T> itemMatcher) og 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"))))));

Hvis du finder dette for ulæseligt eller upraktisk, er du måske bedre stillet med en tilpasset Hamcrest-matcher.




  1. Pymongo finder værdi i underdokumenter

  2. Sådan sorteres efter 'værdi' af en specifik nøgle i en ejendom, der er gemt som et array med k-v-par i mongodb

  3. HDFS Disk Balancer Introduktion, betjening og funktioner

  4. Sessionstilstand med Azure Redis Cache fungerer ikke på flere forekomster