mirror of
https://github.com/outbackdingo/patroni.git
synced 2026-01-27 18:20:05 +00:00
Such wait was happening in the main thread and blocking HA loop. After all the executor thread was doing absolutely the same.
28 lines
782 B
Python
28 lines
782 B
Python
import unittest
|
|
|
|
from mock import Mock, patch
|
|
from patroni.callback_executor import CallbackExecutor
|
|
|
|
|
|
class TestCallbackExecutor(unittest.TestCase):
|
|
|
|
@patch('subprocess.Popen')
|
|
def test_callback_executor(self, mock_popen):
|
|
mock_popen.return_value.wait.side_effect = Exception
|
|
mock_popen.return_value.poll.return_value = None
|
|
|
|
ce = CallbackExecutor()
|
|
self.assertIsNone(ce.call([]))
|
|
ce.join()
|
|
|
|
self.assertIsNone(ce.call([]))
|
|
|
|
mock_popen.return_value.kill.side_effect = OSError
|
|
self.assertIsNone(ce.call([]))
|
|
|
|
mock_popen.side_effect = Exception
|
|
ce = CallbackExecutor()
|
|
ce._callback_event.wait = Mock(side_effect=[None, Exception])
|
|
self.assertIsNone(ce.call([]))
|
|
ce.join()
|