Skip to main content

Function Faker

Project description

functionfaker

Lightweight Decorator to cache (memoize) function calls and replay responses for expensive computations and API requests.

Pip installable via pip install functionfaker

Functionfaker offers lightweight and easy to understand function (and method) caching, similar to some of the functionality of the Joblib package. A function response is recorded once and then replayed from cache from thereon. This allows for unit testing applications with API calls without actaully calling the API. It can also speed up prototyping of computationally expensive code. Functionfaker consists of simple code, and provides a single decorator for your functions and methods, as shown in the following "hello world" example.

from functionfaker import response_player
import os

Add the response_player decorator to an example function called add:

@response_player()
def add(x, y):
    return x + y

Then set RECORD mode by setting the environment variable:

# enter record mode, to record function responses.
os.environ['RECORD'] = "record"

Call the add function a few times:

# Clear the stored function responses
if os.path.exists('responses.p'):
    os.remove('responses.p')
# call the add function to record some responses.
add(1,2)
add(1,y=3)
add(1,3)
add(2,1)
Recording response function "add"
Recording response function "add"
Recording response function "add"

Set replay mode via the environment variable:

# enter replay mode, so that function will not run, but return stored values instead.
os.environ['RECORD'] = "replay"

Call the add function again, with arguments that it has already seen:

result = add(1,2)
print("The saved result of adding 1 and 2 using function 'add' is %d"%result)
Faking function "add". Response found
The saved result of adding 1 and 2 using function 'add' is 3

The outputs for these inputs (1,2) are now read from cache.

Some funtion arguments might be irrelevant or difficult to serialize. To ignore these arguments, provide the args2ignore argument as a list of integers to the response_player decorator, where the integers represent the index in the argument list.

Default function response storage is in a simple Pickle file responses.p. To use your own storage system, provide a class derived from BaseStore class with an update and get_response method. An object of this class is then provided as the store argument to the response_player decorator.

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

functionfaker-0.2.tar.gz (4.4 kB view details)

Uploaded Source

File details

Details for the file functionfaker-0.2.tar.gz.

File metadata

  • Download URL: functionfaker-0.2.tar.gz
  • Upload date:
  • Size: 4.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.2

File hashes

Hashes for functionfaker-0.2.tar.gz
Algorithm Hash digest
SHA256 c9af20400c61403cbd975e57fda4be9c5b10c906cecf81f75a8f6dca97b6133e
MD5 9e3332e27d207e4fce0ae20f6d8267e0
BLAKE2b-256 f877b7d3c2ba3b0cb486ef631aa3be3f6a5097f1c605c4948c2e331bc5147c02

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