skip to navigation
skip to content

Not Logged In

betamax 0.1.6

A VCR imitation for python-requests

Latest Version: 0.2.0

betamax

Betamax is a VCR imitation for requests. This will make mocking out requests much easier. It is tested on Travis CI.

Put in a more humorous way: "Betamax records your HTTP interactions so the NSA does not have to."

Example Use

from betamax import Betamax
from requests import Session
from unittest import TestCase

with Betamax.configure() as config:
    config.cassette_library_dir = 'tests/fixtures/cassettes'


class TestGitHubAPI(TestCase):
    def setUp(self):
        self.session = Session()
        self.headers.update(...)

    # Set the cassette in a line other than the context declaration
    def test_user(self):
        with Betamax(self.session) as vcr:
            vcr.use_cassette('user')
            resp = self.session.get('https://api.github.com/user',
                                    auth=('user', 'pass'))
            assert resp.json()['login'] is not None

    # Set the cassette in line with the context declaration
    def test_repo(self):
        with Betamax(self.session).use_cassette('repo'):
            resp = self.session.get(
                'https://api.github.com/repos/sigmavirus24/github3.py'
                )
            assert resp.json()['owner'] != {}

What does it even do?

If you are unfamiliar with VCR, you might need a better explanation of what Betamax does.

Betamax intercepts every request you make and attempts to find a matching request that has already been intercepted and recorded. Two things can then happen:

  1. If there is a matching request, it will return the response that is associated with it.
  2. If there is not a matching request and it is allowed to record new responses, it will make the request, record the response and return the response.

Recorded requests and corresponding responses - also known as interactions - are stored in files called cassettes. (An example cassette can be seen in the examples section of the documentation.) The directory you store your cassettes in is called your library, or your cassette library.

VCR Cassette Compatiblity

Betamax can use any VCR-recorded cassette as of this point in time. The only caveat is that python-requests returns a URL on each response. VCR does not store that in a cassette now but we will. Any VCR-recorded cassette used to playback a response will unfortunately not have a URL attribute on responses that are returned. This is a minor annoyance but not something that can be fixed.

Contributing

You can check out the project board on waffle.io to see what the status of each issue is.

History

0.1.6 - 2013-xx-xx

  • Fix how global settings and per-invocation options are persisted and honored. (#10)
  • Support match_requests_on as a parameter sent to Betamax#use_cassette. (No issue)

0.1.5 - 2013-09-27

  • Make sure what we pass to base64.b64decode is a bytes object

0.1.4 - 2013-09-27

  • Do not try to sanitize something that may not exist.

0.1.3 - 2013-09-27

  • Fix issue when response has a Content-Encoding of gzip and we need to preserve the original bytes of the message.

0.1.2 - 2013-09-21

  • Fix issues with how requests parses cookies out of responses
  • Fix unicode issues with Response#text (trying to use Response#json raises exception because it cannot use string decoding on a unicode string)

0.1.1 - 2013-09-19

  • Fix issue where there is a unicode character not in range(128)

0.1.0 - 2013-09-17

  • Initial Release
  • Support for VCR generated cassettes (JSON only)
  • Support for re_record_interval
  • Support for the once, all, new_episodes, all cassette modes
  • Support for filtering sensitive data
  • Support for the following methods of request matching:
    • Method
    • URI
    • Host
    • Path
    • Query String
    • Body
    • Headers
 
File Type Py Version Uploaded on Size
betamax-0.1.6-py27-none-any.whl (md5) Python Wheel 2.7 2013-12-07 16KB
betamax-0.1.6.tar.gz (md5) Source 2013-12-07 11KB
  • Downloads (All Versions):
  • 90 downloads in the last day
  • 514 downloads in the last week
  • 2863 downloads in the last month