4 # Copyright (C) 2006, 2007, 2008, 2010 Google Inc.
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.
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.
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
22 """Script for unittesting the objects module"""
27 from ganeti import constants
28 from ganeti import objects
33 class SimpleObject(objects.ConfigObject):
34 __slots__ = ['a', 'b']
37 class TestDictState(unittest.TestCase):
38 """Simple dict tansformation tests"""
40 def testSimpleObjectToDict(self):
41 o1 = SimpleObject(a='1')
42 self.assertEquals(o1.ToDict(), {'a': '1'})
43 self.assertEquals(o1.__getstate__(), {'a': '1'})
44 self.assertEquals(o1.__getstate__(), o1.ToDict())
47 self.assertEquals(o1.ToDict(), {'a': 2, 'b': 5})
48 o2 = SimpleObject.FromDict(o1.ToDict())
49 self.assertEquals(o1.ToDict(), {'a': 2, 'b': 5})
52 class TestClusterObject(unittest.TestCase):
53 """Tests done on a L{objects.Cluster}"""
71 constants.HT_XEN_PVM: {
72 "root_path": "/dev/sda5",
80 constants.ND_OOB_PROGRAM: "/bin/cluster-oob"
83 self.fake_cl = objects.Cluster(hvparams=hvparams, os_hvp=os_hvp,
85 self.fake_cl.UpgradeConfig()
87 def testGetHVDefaults(self):
89 self.failUnlessEqual(cl.GetHVDefaults(constants.HT_FAKE),
90 cl.hvparams[constants.HT_FAKE])
91 self.failUnlessEqual(cl.GetHVDefaults(None), {})
92 self.failUnlessEqual(cl.GetHVDefaults(constants.HT_XEN_PVM,
93 os_name="lenny-image"),
94 cl.os_hvp["lenny-image"][constants.HT_XEN_PVM])
97 def testFillHvFullMerge(self):
109 fake_inst = objects.Instance(name="foobar",
111 hypervisor=constants.HT_FAKE,
112 hvparams=inst_hvparams)
113 self.assertEqual(fake_dict, self.fake_cl.FillHV(fake_inst))
115 def testFillHvGlobalParams(self):
116 fake_inst = objects.Instance(name="foobar",
118 hypervisor=constants.HT_FAKE,
120 self.assertEqual(self.fake_cl.hvparams[constants.HT_FAKE],
121 self.fake_cl.FillHV(fake_inst))
123 def testFillHvInstParams(self):
127 fake_inst = objects.Instance(name="foobar",
129 hypervisor=constants.HT_XEN_PVM,
130 hvparams=inst_hvparams)
131 self.assertEqual(inst_hvparams, self.fake_cl.FillHV(fake_inst))
133 def testFillHvEmptyParams(self):
134 fake_inst = objects.Instance(name="foobar",
136 hypervisor=constants.HT_XEN_PVM,
138 self.assertEqual({}, self.fake_cl.FillHV(fake_inst))
140 def testFillHvPartialParams(self):
142 fake_inst = objects.Instance(name="foobar",
144 hypervisor=constants.HT_XEN_PVM,
146 self.assertEqual(self.fake_cl.os_hvp[os][constants.HT_XEN_PVM],
147 self.fake_cl.FillHV(fake_inst))
149 def testFillNdParamsCluster(self):
150 fake_node = objects.Node(name="test",
153 fake_group = objects.NodeGroup(name="testgroup",
155 self.assertEqual(self.fake_cl.ndparams,
156 self.fake_cl.FillND(fake_node, fake_group))
158 def testFillNdParamsNodeGroup(self):
159 fake_node = objects.Node(name="test",
163 constants.ND_OOB_PROGRAM: "/bin/group-oob"
165 fake_group = objects.NodeGroup(name="testgroup",
166 ndparams=group_ndparams)
167 self.assertEqual(group_ndparams,
168 self.fake_cl.FillND(fake_node, fake_group))
170 def testFillNdParamsNode(self):
172 constants.ND_OOB_PROGRAM: "/bin/node-oob"
174 fake_node = objects.Node(name="test",
175 ndparams=node_ndparams,
177 fake_group = objects.NodeGroup(name="testgroup",
179 self.assertEqual(node_ndparams,
180 self.fake_cl.FillND(fake_node, fake_group))
182 def testFillNdParamsAll(self):
184 constants.ND_OOB_PROGRAM: "/bin/node-oob"
186 fake_node = objects.Node(name="test",
187 ndparams=node_ndparams,
190 constants.ND_OOB_PROGRAM: "/bin/group-oob"
192 fake_group = objects.NodeGroup(name="testgroup",
193 ndparams=group_ndparams)
194 self.assertEqual(node_ndparams,
195 self.fake_cl.FillND(fake_node, fake_group))
198 class TestOS(unittest.TestCase):
201 "debootstrap+default",
202 "debootstrap++default",
205 def testSplitNameVariant(self):
206 for name in self.ALL_DATA:
207 self.assertEqual(len(objects.OS.SplitNameVariant(name)), 2)
209 def testVariant(self):
210 self.assertEqual(objects.OS.GetVariant("debootstrap"), "")
211 self.assertEqual(objects.OS.GetVariant("debootstrap+default"), "default")
214 if __name__ == '__main__':
215 testutils.GanetiTestProgram()