Isolate state on the Braintree sandbox during testing.
Project description
A Braintree namespace isolates state on the Braintree gateway:
import braintree
import btnamespace
with btnamespace.Namespace():
customer = braintree.Customer.create({"id": "123"})
assert customer.id == "123"
braintree.Customer.find("123") # success
braintree.Customer.find("123") # NotFound exception
This is primarily useful during integration tests:
def setUp(self):
self.namespace = btnamespace.Namespace()
self.namespace.__enter__()
def test_some_sandbox_integration(self):
#...
def tearDown(self):
self.namespace.__exit__()
Compared to calling eg braintree.Customer.delete during tearDown, this has a number of advantages:
it’s faster, since no teardown is needed
it’s simpler, since it doesn’t require any bookkeeping
it’s robust, since tests can be written without any state assumptions
You can install it with $ pip install btnamespace.
What’s supported
Customer create, update, find, delete
CreditCard create, update, find, delete
Transaction create, find
All operations involving subresources - eg creating a CreditCard and Customer in one call - work as expected.
Adding support for other operations is easy; we just haven’t needed them yet. Contributions welcome!
How it Works
Under the hood, a Namespace globally patches the braintree client library.
During create operations, any provided ids are removed. This forces the gateway to respond with unique ids, which are later mapped back to the originally-provided ids. Here’s an example:
on a call to braintree.Customer.create({'id': '123', ...}), '123' is stored as a Customer id and the call becomes braintree.Customer.create({...}).
then, the server returns a unique id 'abcde' for the Customer. '123' is mapped to 'abcde', and the resulting Customer object’s id is set to '123'.
later, a call to braintree.Customer.find('123') becomes braintree.Customer.find('abcde').
Contributing
Inside your vitualenv:
$ cd btnamespace
$ pip install -e .
$ pip install -r requirements.txt
To run the tests, first add your sandbox credentials:
$ export BT_MERCHANT_ID=merchant-id
$ export BT_PUBLIC_KEY=public-id
$ export BT_PRIVATE_KEY=private-key
Then run $ python tests/test_integration.py.
History
2.0.0
released 2016-07-15
breaking: drop python 2.6 support
fix a bug affecting operations after exiting a namespace
add strict_missing and strict_missing_exception options
1.1.1
released 2014-09-26
pin bidict to 0.1.5 to avoid breaking changes in newer versions
1.1.0
released 2014-07-28
add schema for braintree.ClientToken.generate
1.0.1
released 2014-04-08
use less expensive introspection
remove decorator dependency
1.0.0
released 2014-04-07
initial release
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file btnamespace-2.0.0.tar.gz
.
File metadata
- Download URL: btnamespace-2.0.0.tar.gz
- Upload date:
- Size: 9.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1ad5404c2c81bae02f72a0223225d7a5cc57092532984efd080129ec067e5880 |
|
MD5 | a0b807afed4a4756e8ff9f021af62e49 |
|
BLAKE2b-256 | 39267b3b1fd8a242b30c32150bba65c6aec79b6366aeef720befb4461609f01e |