LGTM.

Thanks,
Jose

On Apr 16 15:19, Ilias Tsitsimpis wrote:
> Now that 'all_nodes' and 'secondary_nodes' of an instance are computed
> from the 'config' module, move the corresponding tests from
> 'objects_unittest' to 'config_unittest'.
> 
> Signed-off-by: Ilias Tsitsimpis <[email protected]>
> ---
>  test/py/ganeti.config_unittest.py  | 87 
> ++++++++++++++++++++++++++++++++++++++
>  test/py/ganeti.objects_unittest.py | 50 +---------------------
>  2 files changed, 88 insertions(+), 49 deletions(-)
> 
> diff --git a/test/py/ganeti.config_unittest.py 
> b/test/py/ganeti.config_unittest.py
> index f70bc31..0c50cc4 100755
> --- a/test/py/ganeti.config_unittest.py
> +++ b/test/py/ganeti.config_unittest.py
> @@ -125,6 +125,93 @@ class TestConfigRunner(unittest.TestCase):
>      self.failUnlessEqual(1, len(cfg.GetNodeList()))
>      self.failUnlessEqual(0, len(cfg.GetInstanceList()))
>  
> +  def _GenericNodesCheck(self, iobj, all_nodes, secondary_nodes):
> +    for i in [all_nodes, secondary_nodes]:
> +      self.assertTrue(isinstance(i, (list, tuple)),
> +                      msg="Data type doesn't guarantee order")
> +
> +    self.assertTrue(iobj.primary_node not in secondary_nodes)
> +    self.assertEqual(all_nodes[0], iobj.primary_node,
> +                     msg="Primary node not first node in list")
> +
> +  def testInstNodesNoDisks(self):
> +    """Test all_nodes/secondary_nodes when there are no disks"""
> +    # construct instance
> +    cfg = self._get_object()
> +    inst = self._create_instance(cfg)
> +    cfg.AddInstance(inst, "my-job")
> +
> +    # No disks
> +    all_nodes = cfg.GetInstanceNodes(inst.uuid)
> +    secondary_nodes = cfg.GetInstanceSecondaryNodes(inst.uuid)
> +    self._GenericNodesCheck(inst, all_nodes, secondary_nodes)
> +    self.assertEqual(len(secondary_nodes), 0)
> +    self.assertEqual(set(all_nodes), set([inst.primary_node]))
> +    self.assertEqual(cfg.GetInstanceLVsByNode(inst.uuid), {
> +      inst.primary_node: [],
> +      })
> +
> +  def testInstNodesPlainDisks(self):
> +    # construct instance
> +    cfg = self._get_object()
> +    inst = self._create_instance(cfg)
> +    disks = [
> +      objects.Disk(dev_type=constants.DT_PLAIN, size=128,
> +                   logical_id=("myxenvg", "disk25494")),
> +      objects.Disk(dev_type=constants.DT_PLAIN, size=512,
> +                   logical_id=("myxenvg", "disk29071")),
> +      ]
> +    inst.disks = disks
> +    cfg.AddInstance(inst, "my-job")
> +
> +    # Plain disks
> +    all_nodes = cfg.GetInstanceNodes(inst.uuid)
> +    secondary_nodes = cfg.GetInstanceSecondaryNodes(inst.uuid)
> +    self._GenericNodesCheck(inst, all_nodes, secondary_nodes)
> +    self.assertEqual(len(secondary_nodes), 0)
> +    self.assertEqual(set(all_nodes), set([inst.primary_node]))
> +    self.assertEqual(cfg.GetInstanceLVsByNode(inst.uuid), {
> +      inst.primary_node: ["myxenvg/disk25494", "myxenvg/disk29071"],
> +      })
> +
> +  def testInstNodesDrbdDisks(self):
> +    # construct a second node
> +    cfg = self._get_object()
> +    node_group = cfg.LookupNodeGroup(None)
> +    master_uuid = cfg.GetMasterNode()
> +    node2 = objects.Node(name="node2.example.com", group=node_group,
> +                         ndparams={}, uuid="node2-uuid")
> +    cfg.AddNode(node2, "my-job")
> +
> +    # construct instance
> +    inst = self._create_instance(cfg)
> +    disks = [
> +      objects.Disk(dev_type=constants.DT_DRBD8, size=786432,
> +                   logical_id=(master_uuid, node2.uuid,
> +                               12300, 0, 0, "secret"),
> +                   children=[
> +                     objects.Disk(dev_type=constants.DT_PLAIN, size=786432,
> +                                  logical_id=("myxenvg", "disk0")),
> +                     objects.Disk(dev_type=constants.DT_PLAIN, size=128,
> +                                  logical_id=("myxenvg", "meta0"))
> +                   ],
> +                   iv_name="disk/0")
> +      ]
> +    inst.disks = disks
> +    cfg.AddInstance(inst, "my-job")
> +
> +    # Drbd Disks
> +    all_nodes = cfg.GetInstanceNodes(inst.uuid)
> +    secondary_nodes = cfg.GetInstanceSecondaryNodes(inst.uuid)
> +    self._GenericNodesCheck(inst, all_nodes, secondary_nodes)
> +    self.assertEqual(set(secondary_nodes), set([node2.uuid]))
> +    self.assertEqual(set(all_nodes),
> +                     set([inst.primary_node, node2.uuid]))
> +    self.assertEqual(cfg.GetInstanceLVsByNode(inst.uuid), {
> +      master_uuid: ["myxenvg/disk0", "myxenvg/meta0"],
> +      node2.uuid: ["myxenvg/disk0", "myxenvg/meta0"],
> +      })
> +
>    def testUpdateCluster(self):
>      """Test updates on the cluster object"""
>      cfg = self._get_object()
> diff --git a/test/py/ganeti.objects_unittest.py 
> b/test/py/ganeti.objects_unittest.py
> index 74ec4b7..9725823 100755
> --- a/test/py/ganeti.objects_unittest.py
> +++ b/test/py/ganeti.objects_unittest.py
> @@ -321,46 +321,7 @@ class TestOS(unittest.TestCase):
>  
>  
>  class TestInstance(unittest.TestCase):
> -  def _GenericCheck(self, inst):
> -    for i in [inst.all_nodes, inst.secondary_nodes]:
> -      self.assertTrue(isinstance(inst.all_nodes, (list, tuple)),
> -                      msg="Data type doesn't guarantee order")
> -
> -    self.assertTrue(inst.primary_node not in inst.secondary_nodes)
> -    self.assertEqual(inst.all_nodes[0], inst.primary_node,
> -                     msg="Primary node not first node in list")
> -
> -  def testNodesNoDisks(self):
> -    inst = objects.Instance(name="fakeinst.example.com",
> -      primary_node="pnode.example.com",
> -      disks=[
> -        ])
> -
> -    self._GenericCheck(inst)
> -    self.assertEqual(len(inst.secondary_nodes), 0)
> -    self.assertEqual(set(inst.all_nodes), set([inst.primary_node]))
> -    self.assertEqual(inst.MapLVsByNode(), {
> -      inst.primary_node: [],
> -      })
> -
> -  def testNodesPlainDisks(self):
> -    inst = objects.Instance(name="fakeinstplain.example.com",
> -      primary_node="node3.example.com",
> -      disks=[
> -        objects.Disk(dev_type=constants.DT_PLAIN, size=128,
> -                     logical_id=("myxenvg", "disk25494")),
> -        objects.Disk(dev_type=constants.DT_PLAIN, size=512,
> -                     logical_id=("myxenvg", "disk29071")),
> -        ])
> -
> -    self._GenericCheck(inst)
> -    self.assertEqual(len(inst.secondary_nodes), 0)
> -    self.assertEqual(set(inst.all_nodes), set([inst.primary_node]))
> -    self.assertEqual(inst.MapLVsByNode(), {
> -      inst.primary_node: ["myxenvg/disk25494", "myxenvg/disk29071"],
> -      })
> -
> -  def testNodesDrbdDisks(self):
> +  def testFindDisk(self):
>      inst = objects.Instance(name="fakeinstdrbd.example.com",
>        primary_node="node20.example.com",
>        disks=[
> @@ -376,15 +337,6 @@ class TestInstance(unittest.TestCase):
>            iv_name="disk/0")
>          ])
>  
> -    self._GenericCheck(inst)
> -    self.assertEqual(set(inst.secondary_nodes), set(["node15.example.com"]))
> -    self.assertEqual(set(inst.all_nodes),
> -                     set([inst.primary_node, "node15.example.com"]))
> -    self.assertEqual(inst.MapLVsByNode(), {
> -      inst.primary_node: ["myxenvg/disk0", "myxenvg/meta0"],
> -      "node15.example.com": ["myxenvg/disk0", "myxenvg/meta0"],
> -      })
> -
>      self.assertEqual(inst.FindDisk(0), inst.disks[0])
>      self.assertRaises(errors.OpPrereqError, inst.FindDisk, "hello")
>      self.assertRaises(errors.OpPrereqError, inst.FindDisk, 100)
> -- 
> 1.9.1
> 

-- 
Jose Antonio Lopes
Ganeti Engineering
Google Germany GmbH
Dienerstr. 12, 80331, München

Registergericht und -nummer: Hamburg, HRB 86891
Sitz der Gesellschaft: Hamburg
Geschäftsführer: Graham Law, Christine Elizabeth Flores
Steuernummer: 48/725/00206
Umsatzsteueridentifikationsnummer: DE813741370

Reply via email to