Hide keyboard shortcuts

Hot-keys on this page

r m x p   toggle line displays

j k   next/prev highlighted chunk

0   (zero) top of page

1   (one) first highlighted chunk

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

# -*- coding: utf-8 -*- 

# 

# Licensed under the Apache License, Version 2.0 (the "License"); 

# you may not use this file except in compliance with the License. 

# You may obtain a copy of the License at 

# 

# http://www.apache.org/licenses/LICENSE-2.0 

# 

# Unless required by applicable law or agreed to in writing, software 

# distributed under the License is distributed on an "AS IS" BASIS, 

# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 

# See the License for the specific language governing permissions and 

# limitations under the License. 

# 

from __future__ import absolute_import 

from __future__ import division 

from __future__ import print_function 

from __future__ import unicode_literals 

 

import logging 

import signal 

 

from builtins import object 

 

from airflow.exceptions import AirflowTaskTimeout 

 

 

class timeout(object): 

""" 

To be used in a ``with`` block and timeout its content. 

""" 

def __init__(self, seconds=1, error_message='Timeout'): 

self.seconds = seconds 

self.error_message = error_message 

 

def handle_timeout(self, signum, frame): 

logging.error("Process timed out") 

raise AirflowTaskTimeout(self.error_message) 

 

def __enter__(self): 

try: 

signal.signal(signal.SIGALRM, self.handle_timeout) 

signal.alarm(self.seconds) 

except ValueError as e: 

logging.warning("timeout can't be used in the current context") 

logging.exception(e) 

 

def __exit__(self, type, value, traceback): 

try: 

signal.alarm(0) 

except ValueError as e: 

logging.warning("timeout can't be used in the current context") 

logging.exception(e)