I’m writing a very small Python ORM around boto.dynamodb.layer2. I would like to write tests for it, but I don’t want the tests to actually communicate with AWS, as this would require complicated setup, credentials, network access, etc.
Since I plan to open source the module, including credentials in the source seems like a bad idea since I will get charged for usage, and including credentials in the environment is a pain.
Coupling my tests to the network seems like a bad idea, as it makes the tests run slower, or may cause tests to fail due to network errors or throttling. My goal is not to test boto’s DynamoDB interface, or AWS. I just want to test my own code.
I plan to use unittest2 to write the tests and mock to mock out the parts of boto that hit the network, but I’ve never done this before, so my question boils down to these:
- Am I going about this the right way?
- Has anyone else done this?
- Are there any particular points in the
boto.dynamodbinterface that would be best to mock out?
To answer my questions fully:
As with @pcalcao’s answer, mocking out the service was the right thing to do. It wasn’t even as hard as I thought it would be–the test code is only marginally longer than the code under test, and most of it is tests, not plumbing.
Thanks to @gamaat for getting me to take a second look, boto does do this in its own tests, mocking at the actual transport interface level, in
httplib.Mocking the
boto.dynamodb.layer1interface (along withboto.connect_dynamodb) turned out to be the right thing to do. Setting spies onboto.dynamodb.layer2andboto.dynamodb.tablealso helped. Once I began to understand it, I found thatmockis a joy to work with.Here’s my solution, BSD licensed.
I’ll be posting the entire library to PyPI once I’ve dog-fooded it a bit longer and put together some proper documentation.I’ve posted it to PyPI.