Skip to main content

Timeout decorator for sync and async functions

Project description

Timeout function decorator

Test package Release package PyPI - License codecov Code style: black PyPI version PyPI - Python Version Downloads

Timeout decorator for synchronous and asynchronous functions.

Dependencies

Written in pure Python and has no dependencies other than the base libraries.

Installation

From source code:

pip install .

From PyPI:

pip install timeout-function-decorator

Import

There are three ways to import the decorator:

  1. Import directly from the package
from timeout_function_decorator import timeout
  1. Import directly from the module
from timeout_function_decorator.timeout_decorator import timeout
  1. Import the module
from timeout_function_decorator import timeout_decorator

This last case is useful if a timeout function is already present in your namespace.

Usage

Using the decorator is as simple as:

import time
from timeout_function_decorator import timeout


@timeout()
def i_will_never_time_out(value):
    while True:
        time.sleep(1)

        
@timeout(None)
def i_will_never_time_out(value):
    while True:
        time.sleep(1)
        

@timeout(1)
def i_will_not_time_out(value):
    return value


@timeout(1)
def i_will_time_out(value):
    time.sleep(2)
    return value


@timeout(1, RuntimeError)
def i_will_raise_runtime_error(value):
    time.sleep(2)
    return value

As you may have noticed, the decorator requires the brackets even when no parameters are passed.

The same result could be obtained for asynchronous functions:

import asyncio
from timeout_function_decorator import timeout


@timeout()
async def i_will_never_time_out(value):
    while True:
        await asyncio.sleep(1)

        
@timeout(None)
async def i_will_never_time_out(value):
    while True:
        await asyncio.sleep(1)
        

@timeout(1)
async def i_will_not_time_out(value):
    return value


@timeout(1)
async def i_will_time_out(value):
    await asyncio.sleep(2)
    return value


@timeout(1, RuntimeError)
async def i_will_raise_runtime_error(value):
    await asyncio.sleep(2)
    return value

If you already have a timeout function in your namespace, you could as easily use the decorator with the module namespace:

import time
from timeout_function_decorator import timeout_decorator


@timeout_decorator.timeout(1)
def i_still_time_out(value):
    time.sleep(2)
    return value

:warning: Warning: When a function times out, an exception is raised but cancellation is not guaranteed. This decorator only notifies the user when enough time has passed since a function call. Handling of the situation and ensuring cancellation is up to the user.

Signature

In general, the decorator accepts two parameters:

  • timeout_duration: a float specifying the timeout time in seconds. If None, the function will not time out. Defaults to None
  • exception_to_raise: the Exception type to be raised. Defaults to TimeoutError.

They can be passed as positional or keyword arguments.

Intended use cases

The wrapper uses asyncio and threads to keep track of timeouts. This adds a non-trivial overhead on the wrapped functions, in particular on the synchronous ones as they need a thread to be created.

As such, common use cases would include test suites where control on what happens when they time out is important, as with packages like pytest-timeout you can not have tests fail with a specified exception.

Use cases in production code, on the other hand, would be limited to long functions with a low call rate as the overhead is linear with the number of calls but independent of the size of the function or its execution time.

A notebook outlining the impact of the overhead on sync and async functions can be found here.

Plots from the notebook are presented below for a quick performance evaluation.

Performance evaluation

General performance

general_performance

Sync performance

sync_performance

Quick function performance

quick_sync_performance

Medium function performance

medium_sync_performance

Long function performance

long_sync_performance

Huge function performance

huge_sync_performance

Async performance

async_performance

Quick function performance

quick_async_performance

Medium function performance

medium_async_performance

Long function performance

long_async_performance

Huge function performance

huge_async_performance

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

timeout-function-decorator-2.0.0.tar.gz (15.8 kB view details)

Uploaded Source

Built Distribution

timeout_function_decorator-2.0.0-py3-none-any.whl (16.5 kB view details)

Uploaded Python 3

File details

Details for the file timeout-function-decorator-2.0.0.tar.gz.

File metadata

File hashes

Hashes for timeout-function-decorator-2.0.0.tar.gz
Algorithm Hash digest
SHA256 9ad17a5a9a9edb5129ca8c6355eaaab3bd97c4ee703f8af106ca872e98334409
MD5 2577d52e9ee96a946fc79798f0e651b8
BLAKE2b-256 cab1ccfea33f5d8b2f13419d08d801a584120ddec57accacf5225ea98bf3c868

See more details on using hashes here.

File details

Details for the file timeout_function_decorator-2.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for timeout_function_decorator-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5d80b617f0b0f90d6eee6a64ceb5d98cf5c28f77f190b8f304670c0116fd9045
MD5 6676400663f38f949e8b1a432825e5cf
BLAKE2b-256 ff4619a778e4162a3e021168f6f20c5228ba891dfa5234844b7eabeb29be0a26

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