Statistics
| Branch: | Tag: | Revision:

root / test / ganeti.hypervisor_unittest.py @ 415feb2e

History | View | Annotate | Download (1.7 kB)

1
#!/usr/bin/python
2
#
3

    
4
# Copyright (C) 2010 Google Inc.
5
#
6
# This program is free software; you can redistribute it and/or modify
7
# it under the terms of the GNU General Public License as published by
8
# the Free Software Foundation; either version 2 of the License, or
9
# (at your option) any later version.
10
#
11
# This program is distributed in the hope that it will be useful, but
12
# WITHOUT ANY WARRANTY; without even the implied warranty of
13
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14
# General Public License for more details.
15
#
16
# You should have received a copy of the GNU General Public License
17
# along with this program; if not, write to the Free Software
18
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19
# 02110-1301, USA.
20

    
21

    
22
"""Script for testing hypervisor functionality"""
23

    
24
import unittest
25

    
26
from ganeti import constants
27
from ganeti import compat
28
from ganeti import objects
29
from ganeti import errors
30
from ganeti import hypervisor
31

    
32
import testutils
33

    
34

    
35
class TestParameters(unittest.TestCase):
36
  def test(self):
37
    for hv, const_params in constants.HVC_DEFAULTS.items():
38
      hyp = hypervisor.GetHypervisorClass(hv)
39
      for pname in const_params:
40
        self.assertTrue(pname in hyp.PARAMETERS,
41
                        "Hypervisor %s: parameter %s defined in constants"
42
                        " but not in the permitted hypervisor parameters" %
43
                        (hv, pname))
44
      for pname in hyp.PARAMETERS:
45
        self.assertTrue(pname in const_params,
46
                        "Hypervisor %s: parameter %s defined in the hypervisor"
47
                        " but missing a default value" %
48
                        (hv, pname))
49

    
50

    
51
if __name__ == "__main__":
52
  testutils.GanetiTestProgram()