2016-02-01 14:24:02 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
# Import Python libs
|
|
|
|
from __future__ import absolute_import
|
|
|
|
|
|
|
|
# Import Salt Libs
|
|
|
|
from salt.states import mac_defaults as macdefaults
|
|
|
|
|
|
|
|
# Import Salt Testing Libs
|
|
|
|
from salttesting import TestCase
|
|
|
|
from salttesting.helpers import ensure_in_syspath
|
|
|
|
from salttesting.mock import (
|
|
|
|
MagicMock,
|
|
|
|
patch
|
|
|
|
)
|
|
|
|
|
|
|
|
ensure_in_syspath('../../')
|
|
|
|
|
|
|
|
macdefaults.__salt__ = {}
|
|
|
|
|
|
|
|
|
|
|
|
class MacDefaultsTestCase(TestCase):
|
|
|
|
|
|
|
|
def test_write(self):
|
|
|
|
'''
|
|
|
|
Test writing a default setting
|
|
|
|
'''
|
|
|
|
expected = {
|
|
|
|
'changes': {'written': 'com.apple.CrashReporter DialogType is set to Server'},
|
|
|
|
'comment': '',
|
|
|
|
'name': 'DialogType',
|
|
|
|
'result': True
|
|
|
|
}
|
|
|
|
|
|
|
|
read_mock = MagicMock(return_value='Local')
|
|
|
|
write_mock = MagicMock(return_value={'retcode': 0})
|
|
|
|
with patch.dict(macdefaults.__salt__, {'macdefaults.read': read_mock,
|
|
|
|
'macdefaults.write': write_mock}):
|
|
|
|
out = macdefaults.write('DialogType', 'com.apple.CrashReporter', 'Server')
|
|
|
|
read_mock.assert_called_once_with('com.apple.CrashReporter', 'DialogType', None)
|
|
|
|
write_mock.assert_called_once_with('com.apple.CrashReporter', 'DialogType', 'Server', 'string', None)
|
|
|
|
self.assertEqual(out, expected)
|
|
|
|
|
|
|
|
def test_write_set(self):
|
|
|
|
'''
|
|
|
|
Test writing a default setting that is already set
|
|
|
|
'''
|
|
|
|
expected = {
|
|
|
|
'changes': {},
|
|
|
|
'comment': 'com.apple.CrashReporter DialogType is already set to Server',
|
|
|
|
'name': 'DialogType',
|
|
|
|
'result': True
|
|
|
|
}
|
|
|
|
|
|
|
|
read_mock = MagicMock(return_value='Server')
|
|
|
|
write_mock = MagicMock(return_value={'retcode': 0})
|
|
|
|
with patch.dict(macdefaults.__salt__, {'macdefaults.read': read_mock,
|
|
|
|
'macdefaults.write': write_mock}):
|
|
|
|
out = macdefaults.write('DialogType', 'com.apple.CrashReporter', 'Server')
|
|
|
|
read_mock.assert_called_once_with('com.apple.CrashReporter', 'DialogType', None)
|
|
|
|
assert not write_mock.called
|
|
|
|
self.assertEqual(out, expected)
|
|
|
|
|
|
|
|
def test_write_boolean(self):
|
|
|
|
'''
|
|
|
|
Test writing a default setting with a boolean
|
|
|
|
'''
|
|
|
|
expected = {
|
|
|
|
'changes': {'written': 'com.apple.something Key is set to True'},
|
|
|
|
'comment': '',
|
|
|
|
'name': 'Key',
|
|
|
|
'result': True
|
|
|
|
}
|
|
|
|
|
|
|
|
read_mock = MagicMock(return_value='0')
|
|
|
|
write_mock = MagicMock(return_value={'retcode': 0})
|
|
|
|
with patch.dict(macdefaults.__salt__, {'macdefaults.read': read_mock,
|
|
|
|
'macdefaults.write': write_mock}):
|
2016-02-02 08:00:30 +00:00
|
|
|
out = macdefaults.write('Key', 'com.apple.something', True, vtype='boolean')
|
2016-02-01 14:24:02 +00:00
|
|
|
read_mock.assert_called_once_with('com.apple.something', 'Key', None)
|
|
|
|
write_mock.assert_called_once_with('com.apple.something', 'Key', True, 'boolean', None)
|
|
|
|
self.assertEqual(out, expected)
|
|
|
|
|
|
|
|
def test_write_boolean_match(self):
|
|
|
|
'''
|
|
|
|
Test writing a default setting with a boolean that is already set to the same value
|
|
|
|
'''
|
|
|
|
expected = {
|
|
|
|
'changes': {},
|
2016-02-02 08:00:30 +00:00
|
|
|
'comment': 'com.apple.something Key is already set to YES',
|
2016-02-01 14:24:02 +00:00
|
|
|
'name': 'Key',
|
|
|
|
'result': True
|
|
|
|
}
|
|
|
|
|
|
|
|
read_mock = MagicMock(return_value='1')
|
|
|
|
write_mock = MagicMock(return_value={'retcode': 0})
|
|
|
|
with patch.dict(macdefaults.__salt__, {'macdefaults.read': read_mock,
|
|
|
|
'macdefaults.write': write_mock}):
|
2016-02-02 08:00:30 +00:00
|
|
|
out = macdefaults.write('Key', 'com.apple.something', 'YES', vtype='boolean')
|
2016-02-01 14:24:02 +00:00
|
|
|
read_mock.assert_called_once_with('com.apple.something', 'Key', None)
|
|
|
|
assert not write_mock.called
|
|
|
|
self.assertEqual(out, expected)
|
|
|
|
|
|
|
|
def test_write_integer(self):
|
|
|
|
'''
|
|
|
|
Test writing a default setting with a integer
|
|
|
|
'''
|
|
|
|
expected = {
|
|
|
|
'changes': {'written': 'com.apple.something Key is set to 1337'},
|
|
|
|
'comment': '',
|
|
|
|
'name': 'Key',
|
|
|
|
'result': True
|
|
|
|
}
|
|
|
|
|
|
|
|
read_mock = MagicMock(return_value='99')
|
|
|
|
write_mock = MagicMock(return_value={'retcode': 0})
|
|
|
|
with patch.dict(macdefaults.__salt__, {'macdefaults.read': read_mock,
|
|
|
|
'macdefaults.write': write_mock}):
|
2016-02-02 08:00:30 +00:00
|
|
|
out = macdefaults.write('Key', 'com.apple.something', 1337, vtype='integer')
|
2016-02-01 14:24:02 +00:00
|
|
|
read_mock.assert_called_once_with('com.apple.something', 'Key', None)
|
|
|
|
write_mock.assert_called_once_with('com.apple.something', 'Key', 1337, 'integer', None)
|
|
|
|
self.assertEqual(out, expected)
|
|
|
|
|
|
|
|
def test_write_integer_match(self):
|
|
|
|
'''
|
|
|
|
Test writing a default setting with a integer that is already set to the same value
|
|
|
|
'''
|
|
|
|
expected = {
|
|
|
|
'changes': {},
|
|
|
|
'comment': 'com.apple.something Key is already set to 1337',
|
|
|
|
'name': 'Key',
|
|
|
|
'result': True
|
|
|
|
}
|
|
|
|
|
|
|
|
read_mock = MagicMock(return_value='1337')
|
|
|
|
write_mock = MagicMock(return_value={'retcode': 0})
|
|
|
|
with patch.dict(macdefaults.__salt__, {'macdefaults.read': read_mock,
|
|
|
|
'macdefaults.write': write_mock}):
|
2016-02-02 08:00:30 +00:00
|
|
|
out = macdefaults.write('Key', 'com.apple.something', 1337, vtype='integer')
|
2016-02-01 14:24:02 +00:00
|
|
|
read_mock.assert_called_once_with('com.apple.something', 'Key', None)
|
|
|
|
assert not write_mock.called
|
|
|
|
self.assertEqual(out, expected)
|
2016-06-17 13:31:49 +00:00
|
|
|
|
2016-06-17 13:25:42 +00:00
|
|
|
def test_absent_already(self):
|
|
|
|
'''
|
|
|
|
Test ensuring non-existent defaults value is absent
|
|
|
|
'''
|
|
|
|
expected = {
|
|
|
|
'changes': {},
|
|
|
|
'comment': 'com.apple.something Key is already absent',
|
|
|
|
'name': 'Key',
|
|
|
|
'result': True
|
|
|
|
}
|
|
|
|
|
|
|
|
mock = MagicMock(return_value={'retcode': 0}) # this is the macdefaults call retcode? or defaults itself?
|
|
|
|
with patch.dict(macdefaults.__salt__, {'macdefaults.absent': mock}):
|
|
|
|
out = macdefaults.absent('Key', 'com.apple.something')
|
|
|
|
mock.assert_called_once_with('com.apple.something', 'Key', None)
|
|
|
|
assert not write_mock.called
|
|
|
|
self.assertEqual(out, expected)
|
|
|
|
|
|
|
|
def test_absent_deleting_existing(self):
|
|
|
|
'''
|
|
|
|
Test removing an existing value
|
|
|
|
'''
|
|
|
|
expected = {
|
|
|
|
'changes': {},
|
|
|
|
'comment': 'com.apple.something Key is now absent',
|
|
|
|
'name': 'Key',
|
|
|
|
'result': True
|
|
|
|
}
|
|
|
|
|
|
|
|
mock = MagicMock(return_value={'retcode': 0})
|
|
|
|
with patch.dict(macdefaults.__salt__, {'macdefaults.absent': mock}):
|
|
|
|
out = macdefaults.absent('Key', 'com.apple.something')
|
|
|
|
mock.assert_called_once_with('com.apple.something', 'Key')
|
|
|
|
assert not write_mock.called
|
|
|
|
self.assertEqual(out, expected)
|
2016-02-01 14:24:02 +00:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
from integration import run_tests
|
|
|
|
run_tests(MacDefaultsTestCase, needs_daemon=False)
|