Skip to main content

Test utility for redefining functions

Project description

# Redef

To install, just run:

bash
python setup.py build
python setup.py install


See [test_redef.py](/joeheyming/redef/blob/master/test_redef.py) under your install path for examples.

Redef is intended to create lexically scoped variables, that when destroyed, undo mock behavior.
It was inspired by a Perl module, [Test::Resub](http://search.cpan.org/~airwave/Test-Resub-1.02/lib/Test/Resub.pm)

The best examples use unittest, but it should work with any testing framework.

python
import unittest
from redef import redef

class MyClass:
def lame_function(self):
return "something I don't want"

class MyTest(unittest.TestCase):
def test1(self):
myobj = MyClass()
self.assertEqual(myobj.lame_function(), "something I don't want")
want = 'something I want'
rd_lf = redef(MyClass, 'lame_function', lambda s: want)
self.assertEqual(myobj.lame_function(), want)

# after test1, rd_lf gets deleted and resets

def test2(self):
myobj = MyClass()
# test2 is uneffected by test1
self.assertEqual(myobj.lame_function(), "something I don't want")


This doesn't have to be a function, you can also redefine attributes directly on an object.

python
class MyClass:
unpredictable = 'random string'

my_global_object = MyClass()

class MyTest(unittest.TestCase):
def test3(self):
rd_u = redef(my_global_object, 'unpredictable', 'unit testable string')
# ... test something awesome!
self.assertEqual(my_global_object.unpredictable, 'unit testable string')

def test4(self):
# hey, my_global_object is back to being unpredictable
self.assertEqual(my_global_object.unpredictable, 'unpredictable')


There are other useful functions provided on the redef object itself:

* Class Redef:
* __init__:
* takes an object and a key. The rest of the arguments are kwargs:
* if the key doesn't exist in the object, an exception will be raised unless you provide kwargs must_exist
* value: if provided, this value will redefine the key in the object, otherwise you 'wiretap' the object
* must_call: if provided, when the Redef object is destroyed, it warns if this constraint is violated.

* called():
Stores how many times a redef'd function was called.
* method_args():
Stores the most recent *args to the redef'd function.
* named_method_args():
Stores the most recent **kwargs to the redef'd function.
* reset():
Sets called, method_args, and named_method_args back to the default state of 0, None, None
* was_called():
Asks the redef object if there was ever a call. Regardless of calling the reset() function
* never_called():
Asks the redef object if there was never a call. Regardless of calling the reset() function

Redef also provides a freebie static function:

* redef(obj, key, value):
Static constructor of a Redef object

Where
* obj: is a Class, Module, or Object you want to temporariliy change
* key: The string name of the attribute you want to change
* value: The new value. If the value is None, you only capture called, method_args, and named_method_args
* The None case won't redefine the key on the obj

These static functions were provided to show the usefulness of redef:
For example, you could capture stdout of a function call, and after capturing it,
sys.stdout goes back to normal:

* Class CapturedOutput:
* Has 2 variables you want: output, returned

* Static Functions that return a CapturedOutput:
* stdout_of(func, *args, **kwargs):
Call a function and capture the stdout.
Returns a CapturedOutput object that has the stdout and the return value of calling func.

* stderr_of(func, *args, **kwargs):
Call a function and capture the stderr.
Returns a CapturedOutput object that has the stderr and the return value of calling func.

* wiretap:
* A static function that creates a Redef object only for the purpose of capturing the method_args and called values.
* The original functionality should remain the same.

Please ask any questions on github: http://github.com/joeheyming/redef/issues

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

redef-1.4.tar.gz (4.6 kB view details)

Uploaded Source

Built Distribution

redef-1.4.macosx-10.8-intel.exe (70.5 kB view details)

Uploaded Source

File details

Details for the file redef-1.4.tar.gz.

File metadata

  • Download URL: redef-1.4.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for redef-1.4.tar.gz
Algorithm Hash digest
SHA256 2d58818ab1ef767d1a0de0d6b990c6a715fee6a96b35a3560b8d4a834b711554
MD5 73158ab603a0c194c5435aa7d6087aa6
BLAKE2b-256 ee74893b01a9b62e22b50e9a42cfff200ba444d90fc9ab15b54a37b5e7a3b89a

See more details on using hashes here.

File details

Details for the file redef-1.4.macosx-10.8-intel.exe.

File metadata

File hashes

Hashes for redef-1.4.macosx-10.8-intel.exe
Algorithm Hash digest
SHA256 bdd47689ac2994871c793a27b7e9f4b41965d6a5de1abe979f5b5285d779c668
MD5 188ff1b76fb02144cd47771a81e701a9
BLAKE2b-256 12642a1826d68a4f761ca24deac1dd8aea9c5c1d9db835e10191b3b2f4d90de6

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page