sql >> Database >  >> NoSQL >> MongoDB

Ingesloten MongoDB bij het uitvoeren van integratietests

Ik heb de Embedded MongoDB-bibliotheek gevonden die er veelbelovend uitziet en doet waar je om hebt gevraagd.

Ondersteunt momenteel MongoDB-versies:1.6.5 naar 3.1.6 , op voorwaarde dat de binaire bestanden nog steeds beschikbaar zijn op de geconfigureerde spiegelserver.

Hier is een kort gebruiksvoorbeeld, dat ik zojuist heb geprobeerd en het werkt perfect:

public class EmbeddedMongoTest {
    private static final String DATABASE_NAME = "embedded";

    private MongodExecutable mongodExe;
    private MongodProcess mongod;
    private Mongo mongo;

    @Before
    public void beforeEach() throws Exception {
        MongoDBRuntime runtime = MongoDBRuntime.getDefaultInstance();
        mongodExe = runtime.prepare(new MongodConfig(Version.V2_3_0, 12345, Network.localhostIsIPv6()));
        mongod = mongodExe.start();
        mongo = new Mongo("localhost", 12345);
    }

    @After
    public void afterEach() throws Exception {
        if (this.mongod != null) {
            this.mongod.stop();
            this.mongodExe.stop();
        }
    }

    @Test
    public void shouldCreateNewObjectInEmbeddedMongoDb() {
        // given
        DB db = mongo.getDB(DATABASE_NAME);
        DBCollection col = db.createCollection("testCollection", new BasicDBObject());

        // when
        col.save(new BasicDBObject("testDoc", new Date()));

        // then
        assertThat(col.getCount(), Matchers.is(1L));
    }
}


  1. MongoDB - bestandsgrootte is enorm en groeit

  2. Alleen-lezen bestandssysteem bij poging mkdir /data/db op Mac

  3. Hoe invoegen als het niet bestaat, anders updaten met mongoengine?

  4. Voeg een soort rijnummer toe aan een mongodb-aggregaatopdracht / pijplijn