|
1 | 1 | import asyncio |
| 2 | +import contextlib |
2 | 3 | import os.path |
3 | 4 | import tempfile |
4 | 5 |
|
5 | 6 | from uvloop import _testbase as tb |
6 | 7 | from uvloop.loop import FileSystemEvent |
7 | 8 |
|
8 | 9 |
|
9 | | -class Test_UV_FS_EVENT_CHANGE(tb.UVTestCase): |
10 | | - async def _file_writer(self): |
11 | | - f = await self.q.get() |
12 | | - while True: |
13 | | - f.write('hello uvloop\n') |
14 | | - f.flush() |
15 | | - x = await self.q.get() |
16 | | - if x is None: |
17 | | - return |
18 | | - |
19 | | - def fs_event_setup(self): |
20 | | - self.change_event_count = 0 |
21 | | - self.fname = '' |
22 | | - self.q = asyncio.Queue() |
23 | | - |
24 | | - def event_cb(self, ev_fname: bytes, evt: FileSystemEvent): |
25 | | - _d, fn = os.path.split(self.fname) |
26 | | - self.assertEqual(ev_fname, fn) |
27 | | - self.assertEqual(evt, FileSystemEvent.CHANGE) |
28 | | - self.change_event_count += 1 |
29 | | - if self.change_event_count < 4: |
30 | | - self.q.put_nowait(0) |
31 | | - else: |
32 | | - self.q.put_nowait(None) |
| 10 | +class Test_UV_FS_Event(tb.UVTestCase): |
| 11 | + def setUp(self): |
| 12 | + super().setUp() |
| 13 | + self.exit_stack = contextlib.ExitStack() |
| 14 | + self.tmp_dir = self.exit_stack.enter_context( |
| 15 | + tempfile.TemporaryDirectory() |
| 16 | + ) |
| 17 | + |
| 18 | + def tearDown(self): |
| 19 | + self.exit_stack.close() |
| 20 | + super().tearDown() |
33 | 21 |
|
34 | 22 | def test_fs_event_change(self): |
35 | | - self.fs_event_setup() |
36 | | - |
37 | | - async def run(write_task): |
38 | | - self.q.put_nowait(tf) |
39 | | - try: |
40 | | - await asyncio.wait_for(write_task, 4) |
41 | | - except asyncio.TimeoutError: |
42 | | - write_task.cancel() |
43 | | - |
44 | | - with tempfile.NamedTemporaryFile('wt') as tf: |
45 | | - self.fname = tf.name.encode() |
46 | | - h = self.loop._monitor_fs(tf.name, self.event_cb) |
| 23 | + change_event_count = 0 |
| 24 | + filename = "fs_event_change.txt" |
| 25 | + path = os.path.join(self.tmp_dir, filename) |
| 26 | + q = asyncio.Queue() |
| 27 | + |
| 28 | + with open(path, 'wt') as f: |
| 29 | + async def file_writer(): |
| 30 | + while True: |
| 31 | + f.write('hello uvloop\n') |
| 32 | + f.flush() |
| 33 | + x = await q.get() |
| 34 | + if x is None: |
| 35 | + return |
| 36 | + |
| 37 | + def event_cb(ev_fname: bytes, evt: FileSystemEvent): |
| 38 | + nonlocal change_event_count |
| 39 | + self.assertEqual(ev_fname, filename.encode()) |
| 40 | + self.assertEqual(evt, FileSystemEvent.CHANGE) |
| 41 | + change_event_count += 1 |
| 42 | + if change_event_count < 4: |
| 43 | + q.put_nowait(0) |
| 44 | + else: |
| 45 | + q.put_nowait(None) |
| 46 | + |
| 47 | + h = self.loop._monitor_fs(path, event_cb) |
| 48 | + self.loop.run_until_complete( |
| 49 | + asyncio.sleep(0.1) # let monitor start |
| 50 | + ) |
47 | 51 | self.assertFalse(h.cancelled()) |
48 | 52 |
|
49 | | - self.loop.run_until_complete(run( |
50 | | - self.loop.create_task(self._file_writer()))) |
| 53 | + self.loop.run_until_complete(asyncio.wait_for(file_writer(), 4)) |
51 | 54 | h.cancel() |
52 | 55 | self.assertTrue(h.cancelled()) |
53 | 56 |
|
54 | | - self.assertEqual(self.change_event_count, 4) |
55 | | - |
56 | | - |
57 | | -class Test_UV_FS_EVENT_RENAME(tb.UVTestCase): |
58 | | - async def _file_renamer(self): |
59 | | - await self.q.get() |
60 | | - os.rename(os.path.join(self.dname, self.changed_name), |
61 | | - os.path.join(self.dname, self.changed_name + "-new")) |
62 | | - await self.q.get() |
63 | | - |
64 | | - def fs_event_setup(self): |
65 | | - self.dname = '' |
66 | | - self.changed_name = "hello_fs_event.txt" |
67 | | - self.changed_set = {self.changed_name, self.changed_name + '-new'} |
68 | | - self.q = asyncio.Queue() |
69 | | - |
70 | | - def event_cb(self, ev_fname: bytes, evt: FileSystemEvent): |
71 | | - ev_fname = ev_fname.decode() |
72 | | - self.assertEqual(evt, FileSystemEvent.RENAME) |
73 | | - self.changed_set.remove(ev_fname) |
74 | | - if len(self.changed_set) == 0: |
75 | | - self.q.put_nowait(None) |
| 57 | + self.assertEqual(change_event_count, 4) |
76 | 58 |
|
77 | 59 | def test_fs_event_rename(self): |
78 | | - self.fs_event_setup() |
79 | | - |
80 | | - async def run(write_task): |
81 | | - self.q.put_nowait(0) |
82 | | - try: |
83 | | - await asyncio.wait_for(write_task, 4) |
84 | | - except asyncio.TimeoutError: |
85 | | - write_task.cancel() |
86 | | - |
87 | | - with tempfile.TemporaryDirectory() as td_name: |
88 | | - self.dname = td_name |
89 | | - f = open(os.path.join(td_name, self.changed_name), 'wt') |
| 60 | + orig_name = "hello_fs_event.txt" |
| 61 | + new_name = "hello_fs_event_rename.txt" |
| 62 | + changed_set = {orig_name, new_name} |
| 63 | + event = asyncio.Event() |
| 64 | + |
| 65 | + async def file_renamer(): |
| 66 | + os.rename(os.path.join(self.tmp_dir, orig_name), |
| 67 | + os.path.join(self.tmp_dir, new_name)) |
| 68 | + await event.wait() |
| 69 | + |
| 70 | + def event_cb(ev_fname: bytes, evt: FileSystemEvent): |
| 71 | + ev_fname = ev_fname.decode() |
| 72 | + self.assertEqual(evt, FileSystemEvent.RENAME) |
| 73 | + changed_set.discard(ev_fname) |
| 74 | + if len(changed_set) == 0: |
| 75 | + event.set() |
| 76 | + |
| 77 | + with open(os.path.join(self.tmp_dir, orig_name), 'wt') as f: |
90 | 78 | f.write('hello!') |
91 | | - f.close() |
92 | | - h = self.loop._monitor_fs(td_name, self.event_cb) |
93 | | - self.assertFalse(h.cancelled()) |
| 79 | + h = self.loop._monitor_fs(self.tmp_dir, event_cb) |
| 80 | + self.loop.run_until_complete(asyncio.sleep(0.5)) # let monitor start |
| 81 | + self.assertFalse(h.cancelled()) |
94 | 82 |
|
95 | | - self.loop.run_until_complete(run( |
96 | | - self.loop.create_task(self._file_renamer()))) |
97 | | - h.cancel() |
98 | | - self.assertTrue(h.cancelled()) |
| 83 | + self.loop.run_until_complete(asyncio.wait_for(file_renamer(), 4)) |
| 84 | + h.cancel() |
| 85 | + self.assertTrue(h.cancelled()) |
99 | 86 |
|
100 | | - self.assertEqual(len(self.changed_set), 0) |
| 87 | + self.assertEqual(len(changed_set), 0) |
0 commit comments