From 702dbc0a247c149d53b52d1929f9880bc99d0522 Mon Sep 17 00:00:00 2001 From: "Yan, Zheng" Date: Wed, 15 Oct 2014 12:00:58 +0800 Subject: [PATCH] qa/workunits/fs/misc: Add a workunit for file lock interruption Signed-off-by: Yan, Zheng (cherry picked from commit ac92c455a9aa19e4288acdf0c9a746e03a640efb) --- qa/workunits/fs/misc/filelock_interrupt.py | 78 ++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100755 qa/workunits/fs/misc/filelock_interrupt.py diff --git a/qa/workunits/fs/misc/filelock_interrupt.py b/qa/workunits/fs/misc/filelock_interrupt.py new file mode 100755 index 0000000000000..386fbd7163541 --- /dev/null +++ b/qa/workunits/fs/misc/filelock_interrupt.py @@ -0,0 +1,78 @@ +#!/usr/bin/python + +import time +import fcntl +import errno +import signal +import struct + +""" +introduced by Linux 3.15 +""" +fcntl.F_OFD_GETLK=36 +fcntl.F_OFD_SETLK=37 +fcntl.F_OFD_SETLKW=38 + +def handler(signum, frame): + pass + +def main(): + f1 = open("testfile", 'w') + f2 = open("testfile", 'w') + + fcntl.flock(f1, fcntl.LOCK_SH | fcntl.LOCK_NB) + + """ + is flock interruptable? + """ + signal.signal(signal.SIGALRM, handler); + signal.alarm(5); + try: + fcntl.flock(f2, fcntl.LOCK_EX) + except IOError, e: + if e.errno == errno.EINTR: + pass + else: + raise RuntimeError("expect flock to block") + + fcntl.flock(f1, fcntl.LOCK_UN) + + lockdata = struct.pack('hhllhh', fcntl.F_WRLCK, 0, 0, 10, 0, 0) + fcntl.fcntl(f1, fcntl.F_OFD_SETLK, lockdata) + + lockdata = struct.pack('hhllhh', fcntl.F_WRLCK, 0, 10, 10, 0, 0) + fcntl.fcntl(f2, fcntl.F_OFD_SETLK, lockdata) + + """ + is poxis lock interruptable? + """ + signal.signal(signal.SIGALRM, handler); + signal.alarm(5); + try: + lockdata = struct.pack('hhllhh', fcntl.F_WRLCK, 0, 0, 0, 0, 0) + fcntl.fcntl(f2, fcntl.F_OFD_SETLKW, lockdata) + except IOError, e: + if e.errno == errno.EINTR: + pass + else: + raise RuntimeError("expect posix lock to block") + + """ + file handler 2 should still hold lock on 10~10 + """ + try: + lockdata = struct.pack('hhllhh', fcntl.F_WRLCK, 0, 10, 10, 0, 0) + fcntl.fcntl(f1, fcntl.F_OFD_SETLK, lockdata) + except IOError, e: + if e.errno == errno.EAGAIN: + pass + else: + raise RuntimeError("expect file handler 2 to hold lock on 10~10") + + lockdata = struct.pack('hhllhh', fcntl.F_UNLCK, 0, 0, 0, 0, 0) + fcntl.fcntl(f1, fcntl.F_OFD_SETLK, lockdata) + fcntl.fcntl(f2, fcntl.F_OFD_SETLK, lockdata) + + print 'ok' + +main() -- 2.39.5