Use getLogger method instead of a global log object Also use caplog fixture to capture log messages in unit tests. This Fixes #1244
55 lines
1.8 KiB
Python
55 lines
1.8 KiB
Python
import os
|
|
import logging
|
|
from pytest import fixture
|
|
from stat import ST_MODE
|
|
from mock import patch
|
|
|
|
from kiwi.utils.sync import DataSync
|
|
|
|
|
|
class TestDataSync:
|
|
@fixture(autouse=True)
|
|
def inject_fixtures(self, caplog):
|
|
self._caplog = caplog
|
|
|
|
def setup(self):
|
|
self.sync = DataSync('source_dir', 'target_dir')
|
|
|
|
@patch('kiwi.utils.sync.Command.run')
|
|
@patch('kiwi.utils.sync.DataSync.target_supports_extended_attributes')
|
|
@patch('os.chmod')
|
|
@patch('os.stat')
|
|
def test_sync_data(
|
|
self, mock_stat, mock_chmod, mock_xattr_support, mock_command
|
|
):
|
|
mock_stat.return_value = os.stat('.')
|
|
mock_xattr_support.return_value = False
|
|
with self._caplog.at_level(logging.WARNING):
|
|
self.sync.sync_data(
|
|
options=['-a', '-H', '-X', '-A', '--one-file-system'],
|
|
exclude=['exclude_me']
|
|
)
|
|
mock_command.assert_called_once_with(
|
|
[
|
|
'rsync', '-a', '-H', '--one-file-system',
|
|
'--exclude', '/exclude_me', 'source_dir', 'target_dir'
|
|
]
|
|
)
|
|
mock_chmod.assert_called_once_with(
|
|
'target_dir', mock_stat.return_value[ST_MODE]
|
|
)
|
|
|
|
@patch('xattr.getxattr')
|
|
def test_target_supports_extended_attributes(self, mock_getxattr):
|
|
assert self.sync.target_supports_extended_attributes() is True
|
|
mock_getxattr.assert_called_once_with(
|
|
'target_dir', 'user.mime_type'
|
|
)
|
|
|
|
@patch('xattr.getxattr')
|
|
def test_target_does_not_support_extended_attributes(self, mock_getxattr):
|
|
mock_getxattr.side_effect = OSError(
|
|
"""[Errno 95] Operation not supported: b'/boot/efi"""
|
|
)
|
|
assert self.sync.target_supports_extended_attributes() is False
|