Statistics
| Branch: | Tag: | Revision:

root / test / ganeti.mcpu_unittest.py @ 8bc17ebb

History | View | Annotate | Download (8.8 kB)

1 407339d0 Michael Hanselmann
#!/usr/bin/python
2 407339d0 Michael Hanselmann
#
3 407339d0 Michael Hanselmann
4 687c10d9 Iustin Pop
# Copyright (C) 2009, 2011 Google Inc.
5 407339d0 Michael Hanselmann
#
6 407339d0 Michael Hanselmann
# This program is free software; you can redistribute it and/or modify
7 407339d0 Michael Hanselmann
# it under the terms of the GNU General Public License as published by
8 407339d0 Michael Hanselmann
# the Free Software Foundation; either version 2 of the License, or
9 407339d0 Michael Hanselmann
# (at your option) any later version.
10 407339d0 Michael Hanselmann
#
11 407339d0 Michael Hanselmann
# This program is distributed in the hope that it will be useful, but
12 407339d0 Michael Hanselmann
# WITHOUT ANY WARRANTY; without even the implied warranty of
13 407339d0 Michael Hanselmann
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 407339d0 Michael Hanselmann
# General Public License for more details.
15 407339d0 Michael Hanselmann
#
16 407339d0 Michael Hanselmann
# You should have received a copy of the GNU General Public License
17 407339d0 Michael Hanselmann
# along with this program; if not, write to the Free Software
18 407339d0 Michael Hanselmann
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19 407339d0 Michael Hanselmann
# 02110-1301, USA.
20 407339d0 Michael Hanselmann
21 407339d0 Michael Hanselmann
22 407339d0 Michael Hanselmann
"""Script for unittesting the mcpu module"""
23 407339d0 Michael Hanselmann
24 407339d0 Michael Hanselmann
25 407339d0 Michael Hanselmann
import unittest
26 07923a3c Michael Hanselmann
import itertools
27 407339d0 Michael Hanselmann
28 407339d0 Michael Hanselmann
from ganeti import mcpu
29 0a31dda0 Michael Hanselmann
from ganeti import opcodes
30 07923a3c Michael Hanselmann
from ganeti import cmdlib
31 e9a81214 Michael Hanselmann
from ganeti import locking
32 07923a3c Michael Hanselmann
from ganeti import constants
33 d385a174 Iustin Pop
from ganeti.constants import \
34 d385a174 Iustin Pop
    LOCK_ATTEMPTS_TIMEOUT, \
35 d385a174 Iustin Pop
    LOCK_ATTEMPTS_MAXWAIT, \
36 d385a174 Iustin Pop
    LOCK_ATTEMPTS_MINWAIT
37 407339d0 Michael Hanselmann
38 25231ec5 Michael Hanselmann
import testutils
39 25231ec5 Michael Hanselmann
40 407339d0 Michael Hanselmann
41 c9c33a28 Michael Hanselmann
REQ_BGL_WHITELIST = frozenset([
42 c9c33a28 Michael Hanselmann
  opcodes.OpClusterActivateMasterIp,
43 c9c33a28 Michael Hanselmann
  opcodes.OpClusterDeactivateMasterIp,
44 c9c33a28 Michael Hanselmann
  opcodes.OpClusterDestroy,
45 c9c33a28 Michael Hanselmann
  opcodes.OpClusterPostInit,
46 c9c33a28 Michael Hanselmann
  opcodes.OpClusterRename,
47 c9c33a28 Michael Hanselmann
  opcodes.OpInstanceRename,
48 c9c33a28 Michael Hanselmann
  opcodes.OpNodeAdd,
49 c9c33a28 Michael Hanselmann
  opcodes.OpNodeRemove,
50 c9c33a28 Michael Hanselmann
  opcodes.OpTestAllocator,
51 c9c33a28 Michael Hanselmann
  ])
52 c9c33a28 Michael Hanselmann
53 c9c33a28 Michael Hanselmann
54 e3200b18 Michael Hanselmann
class TestLockAttemptTimeoutStrategy(unittest.TestCase):
55 407339d0 Michael Hanselmann
  def testConstants(self):
56 a7770f03 Michael Hanselmann
    tpa = mcpu.LockAttemptTimeoutStrategy._TIMEOUT_PER_ATTEMPT
57 d385a174 Iustin Pop
    self.assert_(len(tpa) > LOCK_ATTEMPTS_TIMEOUT / LOCK_ATTEMPTS_MAXWAIT)
58 d385a174 Iustin Pop
    self.assert_(sum(tpa) >= LOCK_ATTEMPTS_TIMEOUT)
59 407339d0 Michael Hanselmann
60 0b04b188 Michael Hanselmann
    self.assertTrue(LOCK_ATTEMPTS_TIMEOUT >= 1800,
61 0b04b188 Michael Hanselmann
                    msg="Waiting less than half an hour per priority")
62 0b04b188 Michael Hanselmann
    self.assertTrue(LOCK_ATTEMPTS_TIMEOUT <= 3600,
63 0b04b188 Michael Hanselmann
                    msg="Waiting more than an hour per priority")
64 0b04b188 Michael Hanselmann
65 407339d0 Michael Hanselmann
  def testSimple(self):
66 a7770f03 Michael Hanselmann
    strat = mcpu.LockAttemptTimeoutStrategy(_random_fn=lambda: 0.5,
67 a7770f03 Michael Hanselmann
                                            _time_fn=lambda: 0.0)
68 407339d0 Michael Hanselmann
69 407339d0 Michael Hanselmann
    prev = None
70 a7770f03 Michael Hanselmann
    for i in range(len(strat._TIMEOUT_PER_ATTEMPT)):
71 a7770f03 Michael Hanselmann
      timeout = strat.NextAttempt()
72 407339d0 Michael Hanselmann
      self.assert_(timeout is not None)
73 407339d0 Michael Hanselmann
74 d385a174 Iustin Pop
      self.assert_(timeout <= LOCK_ATTEMPTS_MAXWAIT)
75 d385a174 Iustin Pop
      self.assert_(timeout >= LOCK_ATTEMPTS_MINWAIT)
76 407339d0 Michael Hanselmann
      self.assert_(prev is None or timeout >= prev)
77 407339d0 Michael Hanselmann
78 407339d0 Michael Hanselmann
      prev = timeout
79 407339d0 Michael Hanselmann
80 a6db1af2 Michael Hanselmann
    for _ in range(10):
81 a7770f03 Michael Hanselmann
      self.assert_(strat.NextAttempt() is None)
82 407339d0 Michael Hanselmann
83 407339d0 Michael Hanselmann
84 0a31dda0 Michael Hanselmann
class TestDispatchTable(unittest.TestCase):
85 0a31dda0 Michael Hanselmann
  def test(self):
86 0a31dda0 Michael Hanselmann
    for opcls in opcodes.OP_MAPPING.values():
87 687c10d9 Iustin Pop
      if not opcls.WITH_LU:
88 0a31dda0 Michael Hanselmann
        continue
89 687c10d9 Iustin Pop
      self.assertTrue(opcls in mcpu.Processor.DISPATCH_TABLE,
90 687c10d9 Iustin Pop
                      msg="%s missing handler class" % opcls)
91 0a31dda0 Michael Hanselmann
92 c9c33a28 Michael Hanselmann
      # Check against BGL whitelist
93 c9c33a28 Michael Hanselmann
      lucls = mcpu.Processor.DISPATCH_TABLE[opcls]
94 c9c33a28 Michael Hanselmann
      if lucls.REQ_BGL:
95 c9c33a28 Michael Hanselmann
        self.assertTrue(opcls in REQ_BGL_WHITELIST,
96 c9c33a28 Michael Hanselmann
                        msg=("%s not whitelisted for BGL" % opcls.OP_ID))
97 c9c33a28 Michael Hanselmann
      else:
98 c9c33a28 Michael Hanselmann
        self.assertFalse(opcls in REQ_BGL_WHITELIST,
99 c9c33a28 Michael Hanselmann
                         msg=("%s whitelisted for BGL, but doesn't use it" %
100 c9c33a28 Michael Hanselmann
                              opcls.OP_ID))
101 c9c33a28 Michael Hanselmann
102 0a31dda0 Michael Hanselmann
103 07923a3c Michael Hanselmann
class TestProcessResult(unittest.TestCase):
104 07923a3c Michael Hanselmann
  def setUp(self):
105 07923a3c Michael Hanselmann
    self._submitted = []
106 07923a3c Michael Hanselmann
    self._count = itertools.count(200)
107 07923a3c Michael Hanselmann
108 07923a3c Michael Hanselmann
  def _Submit(self, jobs):
109 07923a3c Michael Hanselmann
    job_ids = [self._count.next() for _ in jobs]
110 07923a3c Michael Hanselmann
    self._submitted.extend(zip(job_ids, jobs))
111 07923a3c Michael Hanselmann
    return job_ids
112 07923a3c Michael Hanselmann
113 07923a3c Michael Hanselmann
  def testNoJobs(self):
114 07923a3c Michael Hanselmann
    for i in [object(), [], False, True, None, 1, 929, {}]:
115 07923a3c Michael Hanselmann
      self.assertEqual(mcpu._ProcessResult(NotImplemented, NotImplemented, i),
116 07923a3c Michael Hanselmann
                       i)
117 07923a3c Michael Hanselmann
118 07923a3c Michael Hanselmann
  def testDefaults(self):
119 07923a3c Michael Hanselmann
    src = opcodes.OpTestDummy()
120 07923a3c Michael Hanselmann
121 07923a3c Michael Hanselmann
    res = mcpu._ProcessResult(self._Submit, src, cmdlib.ResultWithJobs([[
122 07923a3c Michael Hanselmann
      opcodes.OpTestDelay(),
123 07923a3c Michael Hanselmann
      opcodes.OpTestDelay(),
124 07923a3c Michael Hanselmann
      ], [
125 07923a3c Michael Hanselmann
      opcodes.OpTestDelay(),
126 07923a3c Michael Hanselmann
      ]]))
127 07923a3c Michael Hanselmann
128 07923a3c Michael Hanselmann
    self.assertEqual(res, {
129 07923a3c Michael Hanselmann
      constants.JOB_IDS_KEY: [200, 201],
130 07923a3c Michael Hanselmann
      })
131 07923a3c Michael Hanselmann
132 07923a3c Michael Hanselmann
    (_, (op1, op2)) = self._submitted.pop(0)
133 07923a3c Michael Hanselmann
    (_, (op3, )) = self._submitted.pop(0)
134 07923a3c Michael Hanselmann
    self.assertRaises(IndexError, self._submitted.pop)
135 07923a3c Michael Hanselmann
136 07923a3c Michael Hanselmann
    for op in [op1, op2, op3]:
137 07923a3c Michael Hanselmann
      self.assertTrue("OP_TEST_DUMMY" in op.comment)
138 07923a3c Michael Hanselmann
      self.assertFalse(hasattr(op, "priority"))
139 07923a3c Michael Hanselmann
      self.assertFalse(hasattr(op, "debug_level"))
140 07923a3c Michael Hanselmann
141 07923a3c Michael Hanselmann
  def testParams(self):
142 07923a3c Michael Hanselmann
    src = opcodes.OpTestDummy(priority=constants.OP_PRIO_HIGH,
143 07923a3c Michael Hanselmann
                              debug_level=3)
144 07923a3c Michael Hanselmann
145 07923a3c Michael Hanselmann
    res = mcpu._ProcessResult(self._Submit, src, cmdlib.ResultWithJobs([[
146 07923a3c Michael Hanselmann
      opcodes.OpTestDelay(priority=constants.OP_PRIO_LOW),
147 07923a3c Michael Hanselmann
      ], [
148 07923a3c Michael Hanselmann
      opcodes.OpTestDelay(comment="foobar", debug_level=10),
149 07923a3c Michael Hanselmann
      ]], other=True, value=range(10)))
150 07923a3c Michael Hanselmann
151 07923a3c Michael Hanselmann
    self.assertEqual(res, {
152 07923a3c Michael Hanselmann
      constants.JOB_IDS_KEY: [200, 201],
153 07923a3c Michael Hanselmann
      "other": True,
154 07923a3c Michael Hanselmann
      "value": range(10),
155 07923a3c Michael Hanselmann
      })
156 07923a3c Michael Hanselmann
157 07923a3c Michael Hanselmann
    (_, (op1, )) = self._submitted.pop(0)
158 07923a3c Michael Hanselmann
    (_, (op2, )) = self._submitted.pop(0)
159 07923a3c Michael Hanselmann
    self.assertRaises(IndexError, self._submitted.pop)
160 07923a3c Michael Hanselmann
161 07923a3c Michael Hanselmann
    self.assertEqual(op1.priority, constants.OP_PRIO_LOW)
162 07923a3c Michael Hanselmann
    self.assertTrue("OP_TEST_DUMMY" in op1.comment)
163 07923a3c Michael Hanselmann
    self.assertEqual(op1.debug_level, 3)
164 07923a3c Michael Hanselmann
165 07923a3c Michael Hanselmann
    self.assertEqual(op2.priority, constants.OP_PRIO_HIGH)
166 07923a3c Michael Hanselmann
    self.assertEqual(op2.comment, "foobar")
167 07923a3c Michael Hanselmann
    self.assertEqual(op2.debug_level, 3)
168 07923a3c Michael Hanselmann
169 07923a3c Michael Hanselmann
170 e9a81214 Michael Hanselmann
class _FakeLuWithLocks:
171 e9a81214 Michael Hanselmann
  def __init__(self, needed_locks, share_locks):
172 e9a81214 Michael Hanselmann
    self.needed_locks = needed_locks
173 e9a81214 Michael Hanselmann
    self.share_locks = share_locks
174 e9a81214 Michael Hanselmann
175 e9a81214 Michael Hanselmann
176 e9a81214 Michael Hanselmann
class _FakeGlm:
177 e9a81214 Michael Hanselmann
  def __init__(self, owning_nal):
178 e9a81214 Michael Hanselmann
    self._owning_nal = owning_nal
179 e9a81214 Michael Hanselmann
180 e9a81214 Michael Hanselmann
  def check_owned(self, level, names):
181 e9a81214 Michael Hanselmann
    assert level == locking.LEVEL_NODE_ALLOC
182 e9a81214 Michael Hanselmann
    assert names == locking.NAL
183 e9a81214 Michael Hanselmann
    return self._owning_nal
184 e9a81214 Michael Hanselmann
185 e9a81214 Michael Hanselmann
  def owning_all(self, level):
186 e9a81214 Michael Hanselmann
    return False
187 e9a81214 Michael Hanselmann
188 e9a81214 Michael Hanselmann
189 e9a81214 Michael Hanselmann
class TestVerifyLocks(unittest.TestCase):
190 e9a81214 Michael Hanselmann
  def testNoLocks(self):
191 e9a81214 Michael Hanselmann
    lu = _FakeLuWithLocks({}, {})
192 e9a81214 Michael Hanselmann
    glm = _FakeGlm(False)
193 e9a81214 Michael Hanselmann
    mcpu._VerifyLocks(lu, glm,
194 e9a81214 Michael Hanselmann
                      _mode_whitelist=NotImplemented,
195 e9a81214 Michael Hanselmann
                      _nal_whitelist=NotImplemented)
196 e9a81214 Michael Hanselmann
197 e9a81214 Michael Hanselmann
  def testNotAllSameMode(self):
198 e9a81214 Michael Hanselmann
    for level in [locking.LEVEL_NODE, locking.LEVEL_NODE_RES]:
199 e9a81214 Michael Hanselmann
      lu = _FakeLuWithLocks({
200 e9a81214 Michael Hanselmann
        level: ["foo"],
201 e9a81214 Michael Hanselmann
        }, {
202 e9a81214 Michael Hanselmann
        level: 0,
203 e9a81214 Michael Hanselmann
        locking.LEVEL_NODE_ALLOC: 0,
204 e9a81214 Michael Hanselmann
        })
205 e9a81214 Michael Hanselmann
      glm = _FakeGlm(False)
206 e9a81214 Michael Hanselmann
      mcpu._VerifyLocks(lu, glm, _mode_whitelist=[], _nal_whitelist=[])
207 e9a81214 Michael Hanselmann
208 e9a81214 Michael Hanselmann
  def testDifferentMode(self):
209 e9a81214 Michael Hanselmann
    for level in [locking.LEVEL_NODE, locking.LEVEL_NODE_RES]:
210 e9a81214 Michael Hanselmann
      lu = _FakeLuWithLocks({
211 e9a81214 Michael Hanselmann
        level: ["foo"],
212 e9a81214 Michael Hanselmann
        }, {
213 e9a81214 Michael Hanselmann
        level: 0,
214 e9a81214 Michael Hanselmann
        locking.LEVEL_NODE_ALLOC: 1,
215 e9a81214 Michael Hanselmann
        })
216 e9a81214 Michael Hanselmann
      glm = _FakeGlm(False)
217 e9a81214 Michael Hanselmann
      try:
218 e9a81214 Michael Hanselmann
        mcpu._VerifyLocks(lu, glm, _mode_whitelist=[], _nal_whitelist=[])
219 e9a81214 Michael Hanselmann
      except AssertionError, err:
220 e9a81214 Michael Hanselmann
        self.assertTrue("using the same mode as nodes" in str(err))
221 e9a81214 Michael Hanselmann
      else:
222 e9a81214 Michael Hanselmann
        self.fail("Exception not raised")
223 e9a81214 Michael Hanselmann
224 e9a81214 Michael Hanselmann
      # Once more with the whitelist
225 e9a81214 Michael Hanselmann
      mcpu._VerifyLocks(lu, glm, _mode_whitelist=[_FakeLuWithLocks],
226 e9a81214 Michael Hanselmann
                        _nal_whitelist=[])
227 e9a81214 Michael Hanselmann
228 e9a81214 Michael Hanselmann
  def testSameMode(self):
229 e9a81214 Michael Hanselmann
    for level in [locking.LEVEL_NODE, locking.LEVEL_NODE_RES]:
230 e9a81214 Michael Hanselmann
      lu = _FakeLuWithLocks({
231 e9a81214 Michael Hanselmann
        level: ["foo"],
232 e9a81214 Michael Hanselmann
        locking.LEVEL_NODE_ALLOC: locking.ALL_SET,
233 e9a81214 Michael Hanselmann
        }, {
234 e9a81214 Michael Hanselmann
        level: 1,
235 e9a81214 Michael Hanselmann
        locking.LEVEL_NODE_ALLOC: 1,
236 e9a81214 Michael Hanselmann
        })
237 e9a81214 Michael Hanselmann
      glm = _FakeGlm(True)
238 e9a81214 Michael Hanselmann
239 e9a81214 Michael Hanselmann
      try:
240 e9a81214 Michael Hanselmann
        mcpu._VerifyLocks(lu, glm, _mode_whitelist=[_FakeLuWithLocks],
241 e9a81214 Michael Hanselmann
                          _nal_whitelist=[])
242 e9a81214 Michael Hanselmann
      except AssertionError, err:
243 e9a81214 Michael Hanselmann
        self.assertTrue("whitelisted to use different modes" in str(err))
244 e9a81214 Michael Hanselmann
      else:
245 e9a81214 Michael Hanselmann
        self.fail("Exception not raised")
246 e9a81214 Michael Hanselmann
247 e9a81214 Michael Hanselmann
      # Once more without the whitelist
248 e9a81214 Michael Hanselmann
      mcpu._VerifyLocks(lu, glm, _mode_whitelist=[], _nal_whitelist=[])
249 e9a81214 Michael Hanselmann
250 e9a81214 Michael Hanselmann
  def testAllWithoutAllocLock(self):
251 e9a81214 Michael Hanselmann
    for level in [locking.LEVEL_NODE, locking.LEVEL_NODE_RES]:
252 e9a81214 Michael Hanselmann
      lu = _FakeLuWithLocks({
253 e9a81214 Michael Hanselmann
        level: locking.ALL_SET,
254 e9a81214 Michael Hanselmann
        }, {
255 e9a81214 Michael Hanselmann
        level: 0,
256 e9a81214 Michael Hanselmann
        locking.LEVEL_NODE_ALLOC: 0,
257 e9a81214 Michael Hanselmann
        })
258 e9a81214 Michael Hanselmann
      glm = _FakeGlm(False)
259 e9a81214 Michael Hanselmann
      try:
260 e9a81214 Michael Hanselmann
        mcpu._VerifyLocks(lu, glm, _mode_whitelist=[], _nal_whitelist=[])
261 e9a81214 Michael Hanselmann
      except AssertionError, err:
262 e9a81214 Michael Hanselmann
        self.assertTrue("allocation lock must be used if" in str(err))
263 e9a81214 Michael Hanselmann
      else:
264 e9a81214 Michael Hanselmann
        self.fail("Exception not raised")
265 e9a81214 Michael Hanselmann
266 e9a81214 Michael Hanselmann
      # Once more with the whitelist
267 e9a81214 Michael Hanselmann
      mcpu._VerifyLocks(lu, glm, _mode_whitelist=[],
268 e9a81214 Michael Hanselmann
                        _nal_whitelist=[_FakeLuWithLocks])
269 e9a81214 Michael Hanselmann
270 e9a81214 Michael Hanselmann
  def testAllWithAllocLock(self):
271 e9a81214 Michael Hanselmann
    for level in [locking.LEVEL_NODE, locking.LEVEL_NODE_RES]:
272 e9a81214 Michael Hanselmann
      lu = _FakeLuWithLocks({
273 e9a81214 Michael Hanselmann
        level: locking.ALL_SET,
274 e9a81214 Michael Hanselmann
        locking.LEVEL_NODE_ALLOC: locking.ALL_SET,
275 e9a81214 Michael Hanselmann
        }, {
276 e9a81214 Michael Hanselmann
        level: 0,
277 e9a81214 Michael Hanselmann
        locking.LEVEL_NODE_ALLOC: 0,
278 e9a81214 Michael Hanselmann
        })
279 e9a81214 Michael Hanselmann
      glm = _FakeGlm(True)
280 e9a81214 Michael Hanselmann
281 e9a81214 Michael Hanselmann
      try:
282 e9a81214 Michael Hanselmann
        mcpu._VerifyLocks(lu, glm, _mode_whitelist=[],
283 e9a81214 Michael Hanselmann
                          _nal_whitelist=[_FakeLuWithLocks])
284 e9a81214 Michael Hanselmann
      except AssertionError, err:
285 e9a81214 Michael Hanselmann
        self.assertTrue("whitelisted for not acquiring" in str(err))
286 e9a81214 Michael Hanselmann
      else:
287 e9a81214 Michael Hanselmann
        self.fail("Exception not raised")
288 e9a81214 Michael Hanselmann
289 e9a81214 Michael Hanselmann
      # Once more without the whitelist
290 e9a81214 Michael Hanselmann
      mcpu._VerifyLocks(lu, glm, _mode_whitelist=[], _nal_whitelist=[])
291 e9a81214 Michael Hanselmann
292 e9a81214 Michael Hanselmann
293 407339d0 Michael Hanselmann
if __name__ == "__main__":
294 25231ec5 Michael Hanselmann
  testutils.GanetiTestProgram()