summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDong-hee Na <donghee.na92@gmail.com>2019-11-07 20:31:41 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2019-11-07 20:31:41 (GMT)
commitbefa032d8869e0fab4732d910f3887642879d644 (patch)
treec9f38b3dc63945bb269f67b4d3bdb0c2c50765cc
parent6cbc84fb99acb33dd659d7adb29a20adbe62b74a (diff)
downloadcpython-befa032d8869e0fab4732d910f3887642879d644.zip
cpython-befa032d8869e0fab4732d910f3887642879d644.tar.gz
cpython-befa032d8869e0fab4732d910f3887642879d644.tar.bz2
bpo-22367: Add tests for fcntl.lockf(). (GH-17010)
-rw-r--r--Lib/test/test_fcntl.py29
1 files changed, 28 insertions, 1 deletions
diff --git a/Lib/test/test_fcntl.py b/Lib/test/test_fcntl.py
index a2b5997..9d1be28 100644
--- a/Lib/test/test_fcntl.py
+++ b/Lib/test/test_fcntl.py
@@ -5,6 +5,7 @@ import os
import struct
import sys
import unittest
+from multiprocessing import Process
from test.support import (verbose, TESTFN, unlink, run_unittest, import_module,
cpython_only)
@@ -12,7 +13,6 @@ from test.support import (verbose, TESTFN, unlink, run_unittest, import_module,
fcntl = import_module('fcntl')
-# TODO - Write tests for flock() and lockf().
def get_lockdata():
try:
@@ -138,6 +138,33 @@ class TestFcntl(unittest.TestCase):
self.assertRaises(ValueError, fcntl.flock, -1, fcntl.LOCK_SH)
self.assertRaises(TypeError, fcntl.flock, 'spam', fcntl.LOCK_SH)
+ def test_lockf_exclusive(self):
+ self.f = open(TESTFN, 'wb+')
+ cmd = fcntl.LOCK_EX | fcntl.LOCK_NB
+ def try_lockf_on_other_process():
+ self.assertRaises(BlockingIOError, fcntl.lockf, self.f, cmd)
+
+ fcntl.lockf(self.f, cmd)
+ p = Process(target=try_lockf_on_other_process)
+ p.start()
+ p.join()
+ fcntl.lockf(self.f, fcntl.LOCK_UN)
+ self.assertEqual(p.exitcode, 0)
+
+ def test_lockf_share(self):
+ self.f = open(TESTFN, 'wb+')
+ cmd = fcntl.LOCK_SH | fcntl.LOCK_NB
+ def try_lockf_on_other_process():
+ fcntl.lockf(self.f, cmd)
+ fcntl.lockf(self.f, fcntl.LOCK_UN)
+
+ fcntl.lockf(self.f, cmd)
+ p = Process(target=try_lockf_on_other_process)
+ p.start()
+ p.join()
+ fcntl.lockf(self.f, fcntl.LOCK_UN)
+ self.assertEqual(p.exitcode, 0)
+
@cpython_only
def test_flock_overflow(self):
import _testcapi