Getting Started =============== Installing ---------- It is available in PyPi, so you can install through pip: .. code:: bash pip install sure pip3 install sure Activating ---------- Sure is activated upon importing it, unless the environment variable ``SURE_DISABLE_NEW_SYNTAX`` is set to any non-falsy value. (You could just use ``true``) For test code cleaningness it's recommended to import sure only once in the ``__init__.py`` of your root test package. Here is an example: .. code:: bash mymodule.py tests/ tests/__init__.py # this is our guy tests/unit/__init__.py tests/unit/test_mymodule_unit1.py tests/functional/__init__.py tests/functional/test_mymodule_functionality.py That is unless, of course, you want to explicitly import the assertion helpers from sure in every module. Python version compatibility ============================ Sure is `continuously tested against `__ python versions 2.7, 3.3, 3.4 and 3.5, but its assertion API is most likely to work anywhere. The only real big difference of sure in cpython and even other implementations such as `PyPy `__ is that the `monkey-patching `__ only happens in CPython. You can always get around beautifully with ``expect``: .. code:: python from sure import expect expect("this".replace("is", "at")).to.equal("that") where in cpython you could do: .. code:: python "this".replace("is", "at").should.equal("that") Disabling the monkey patching ============================= Just export the ``SURE_DISABLE_NEW_SYNTAX`` environment variable before running your tests. .. code:: console export SURE_DISABLE_NEW_SYNTAX=true