Timeout(): un ejemplo real

Escribir funciones en Python

Shayne Miel

Software Architect @ Duo Security

Timeout


def function1():
  # A veces esta función
  # tarda muuuucho
  ...

def function2(): # A veces esta función # se cuelga y no devuelve ...
Escribir funciones en Python

Timeout

@timeout
def function1():
  # A veces esta función
  # tarda muuuucho
  ...

@timeout def function2(): # A veces esta función # se cuelga y no devuelve ...

cronómetro

Escribir funciones en Python

Timeout: información base

import signal

def raise_timeout(*args, **kwargs): raise TimeoutError()
# Cuando salte una señal de "alarma", llama a raise_timeout() signal.signal(signalnum=signal.SIGALRM, handler=raise_timeout)
# Programa una alarma en 5 segundos signal.alarm(5)
# Cancela la alarma signal.alarm(0)
Escribir funciones en Python
def timeout_in_5s(func):

@wraps(func) def wrapper(*args, **kwargs):
# Activa una alarma en 5 segundos signal.alarm(5)
try: # Llama a la función decorada return func(*args, **kwargs)
finalmente: # Cancela la alarma signal.alarm(0)
return wrapper
@timeout_in_5s
def foo():
  time.sleep(10)
  print('foo!')
foo()
TimeoutError
Escribir funciones en Python
def timeout(n_seconds):

def decorator(func):
@wraps(func) def wrapper(*args, **kwargs):
# Activa una alarma en n segundos signal.alarm(n_seconds)
try: # Llama a la función decorada return func(*args, **kwargs) finally: # Cancela la alarma signal.alarm(0)
return wrapper
return decorator
@timeout(5)
def foo():
  time.sleep(10)
  print('foo!')

@timeout(20) def bar(): time.sleep(10) print('bar!')
foo()
TimeoutError
bar()
bar!
Escribir funciones en Python

¡Vamos a practicar!

Escribir funciones en Python

Preparing Video For Download...