/tests/unittests/test_handler/test_handler_power_state.py

https://gitlab.com/waldi/cloud-init · Python · 131 lines · 92 code · 34 blank · 5 comment · 12 complexity · 608190df648d17759d8275c40c083c5a MD5 · raw file

  1. # This file is part of cloud-init. See LICENSE file for license information.
  2. import sys
  3. from cloudinit.config import cc_power_state_change as psc
  4. from .. import helpers as t_help
  5. from ..helpers import mock
  6. class TestLoadPowerState(t_help.TestCase):
  7. def setUp(self):
  8. super(self.__class__, self).setUp()
  9. def test_no_config(self):
  10. # completely empty config should mean do nothing
  11. (cmd, _timeout, _condition) = psc.load_power_state({})
  12. self.assertEqual(cmd, None)
  13. def test_irrelevant_config(self):
  14. # no power_state field in config should return None for cmd
  15. (cmd, _timeout, _condition) = psc.load_power_state({'foo': 'bar'})
  16. self.assertEqual(cmd, None)
  17. def test_invalid_mode(self):
  18. cfg = {'power_state': {'mode': 'gibberish'}}
  19. self.assertRaises(TypeError, psc.load_power_state, cfg)
  20. cfg = {'power_state': {'mode': ''}}
  21. self.assertRaises(TypeError, psc.load_power_state, cfg)
  22. def test_empty_mode(self):
  23. cfg = {'power_state': {'message': 'goodbye'}}
  24. self.assertRaises(TypeError, psc.load_power_state, cfg)
  25. def test_valid_modes(self):
  26. cfg = {'power_state': {}}
  27. for mode in ('halt', 'poweroff', 'reboot'):
  28. cfg['power_state']['mode'] = mode
  29. check_lps_ret(psc.load_power_state(cfg), mode=mode)
  30. def test_invalid_delay(self):
  31. cfg = {'power_state': {'mode': 'poweroff', 'delay': 'goodbye'}}
  32. self.assertRaises(TypeError, psc.load_power_state, cfg)
  33. def test_valid_delay(self):
  34. cfg = {'power_state': {'mode': 'poweroff', 'delay': ''}}
  35. for delay in ("now", "+1", "+30"):
  36. cfg['power_state']['delay'] = delay
  37. check_lps_ret(psc.load_power_state(cfg))
  38. def test_message_present(self):
  39. cfg = {'power_state': {'mode': 'poweroff', 'message': 'GOODBYE'}}
  40. ret = psc.load_power_state(cfg)
  41. check_lps_ret(psc.load_power_state(cfg))
  42. self.assertIn(cfg['power_state']['message'], ret[0])
  43. def test_no_message(self):
  44. # if message is not present, then no argument should be passed for it
  45. cfg = {'power_state': {'mode': 'poweroff'}}
  46. (cmd, _timeout, _condition) = psc.load_power_state(cfg)
  47. self.assertNotIn("", cmd)
  48. check_lps_ret(psc.load_power_state(cfg))
  49. self.assertTrue(len(cmd) == 3)
  50. def test_condition_null_raises(self):
  51. cfg = {'power_state': {'mode': 'poweroff', 'condition': None}}
  52. self.assertRaises(TypeError, psc.load_power_state, cfg)
  53. def test_condition_default_is_true(self):
  54. cfg = {'power_state': {'mode': 'poweroff'}}
  55. _cmd, _timeout, cond = psc.load_power_state(cfg)
  56. self.assertEqual(cond, True)
  57. class TestCheckCondition(t_help.TestCase):
  58. def cmd_with_exit(self, rc):
  59. return([sys.executable, '-c', 'import sys; sys.exit(%s)' % rc])
  60. def test_true_is_true(self):
  61. self.assertEqual(psc.check_condition(True), True)
  62. def test_false_is_false(self):
  63. self.assertEqual(psc.check_condition(False), False)
  64. def test_cmd_exit_zero_true(self):
  65. self.assertEqual(psc.check_condition(self.cmd_with_exit(0)), True)
  66. def test_cmd_exit_one_false(self):
  67. self.assertEqual(psc.check_condition(self.cmd_with_exit(1)), False)
  68. def test_cmd_exit_nonzero_warns(self):
  69. mocklog = mock.Mock()
  70. self.assertEqual(
  71. psc.check_condition(self.cmd_with_exit(2), mocklog), False)
  72. self.assertEqual(mocklog.warn.call_count, 1)
  73. def check_lps_ret(psc_return, mode=None):
  74. if len(psc_return) != 3:
  75. raise TypeError("length returned = %d" % len(psc_return))
  76. errs = []
  77. cmd = psc_return[0]
  78. timeout = psc_return[1]
  79. condition = psc_return[2]
  80. if 'shutdown' not in psc_return[0][0]:
  81. errs.append("string 'shutdown' not in cmd")
  82. if condition is None:
  83. errs.append("condition was not returned")
  84. if mode is not None:
  85. opt = {'halt': '-H', 'poweroff': '-P', 'reboot': '-r'}[mode]
  86. if opt not in psc_return[0]:
  87. errs.append("opt '%s' not in cmd: %s" % (opt, cmd))
  88. if len(cmd) != 3 and len(cmd) != 4:
  89. errs.append("Invalid command length: %s" % len(cmd))
  90. try:
  91. float(timeout)
  92. except Exception:
  93. errs.append("timeout failed convert to float")
  94. if len(errs):
  95. lines = ["Errors in result: %s" % str(psc_return)] + errs
  96. raise Exception('\n'.join(lines))
  97. # vi: ts=4 expandtab