NAME Test::mongod - run a temporrary instance of MongoDB SYNOPSIS use Test::mongod; my $mongod = Test::mongod->new; # thats it, you get a mongod server on a random port and in a /tmp dir ... more $mongod->port; # get the port the server is listening on $mongod->dbpath; # get the db dir DESCRIPTION Test::mongod automatically sets up a temporary instance of MongoDB and destroys it when the script ends. The latest version of this is always at <https://github.com/jshy/Test-mongod> This is "ALPHA" code. METHODS "new" my $mongod = Test::mongod->new; This creates a new instance of "Test::mongod" and instanciates a temporary MongoDB server This uses the moose BUILD method to go ahead and launche the server. This method blocks till the server is listening and ready to work. "stop" $mongo->stop; Stops the MongoDB instance and tears down the temporary directory. This method is called by DEMOLISH when the object goes out of scope. ATTRIBUTES bind_ip The IP to bind the server on. Defaults to 127.0.0.1. Must be an IP on the localhost. port The port for the server to listen on. Defaults to a random port. Use this to get the port to feed to your client. dbpath The diorectory for the database server to put ts files. This defaults to a /tmp directory that will be cleaned up when the script finishes. Changes this will cause the directory to persist. Must be a path on the localhost. pid Contains the pid of the forked child process. config a hashref of config options you can give ether config => { } or config_file => 'relative/path/to/conf/file' config file must be something Config::Any recognizes. SEE EXAMPLE t/etc/mongo.conf if you have a t/etc/mongod.conf file then it will get picked up automatically NOTE: If you use config no config file gets read. AUTHOR Jesse Shy <jshy@cpan.org> COPYRIGHT Copyright 2014- Jesse Shy LICENSE This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. SEE ALSO