Statistics
| Branch: | Tag: | Revision:

root / test / py / ganeti.mcpu_unittest.py @ 4869595d

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 b8028dcf Michael Hanselmann
from ganeti import compat
29 407339d0 Michael Hanselmann
from ganeti import mcpu
30 0a31dda0 Michael Hanselmann
from ganeti import opcodes
31 07923a3c Michael Hanselmann
from ganeti import cmdlib
32 e9a81214 Michael Hanselmann
from ganeti import locking
33 07923a3c Michael Hanselmann
from ganeti import constants
34 d385a174 Iustin Pop
from ganeti.constants import \
35 d385a174 Iustin Pop
    LOCK_ATTEMPTS_TIMEOUT, \
36 d385a174 Iustin Pop
    LOCK_ATTEMPTS_MAXWAIT, \
37 d385a174 Iustin Pop
    LOCK_ATTEMPTS_MINWAIT
38 407339d0 Michael Hanselmann
39 25231ec5 Michael Hanselmann
import testutils
40 25231ec5 Michael Hanselmann
41 407339d0 Michael Hanselmann
42 b8028dcf Michael Hanselmann
REQ_BGL_WHITELIST = compat.UniqueFrozenset([
43 c9c33a28 Michael Hanselmann
  opcodes.OpClusterActivateMasterIp,
44 c9c33a28 Michael Hanselmann
  opcodes.OpClusterDeactivateMasterIp,
45 c9c33a28 Michael Hanselmann
  opcodes.OpClusterDestroy,
46 c9c33a28 Michael Hanselmann
  opcodes.OpClusterPostInit,
47 c9c33a28 Michael Hanselmann
  opcodes.OpClusterRename,
48 c9c33a28 Michael Hanselmann
  opcodes.OpInstanceRename,
49 c9c33a28 Michael Hanselmann
  opcodes.OpNodeAdd,
50 c9c33a28 Michael Hanselmann
  opcodes.OpNodeRemove,
51 c9c33a28 Michael Hanselmann
  opcodes.OpTestAllocator,
52 c9c33a28 Michael Hanselmann
  ])
53 c9c33a28 Michael Hanselmann
54 c9c33a28 Michael Hanselmann
55 e3200b18 Michael Hanselmann
class TestLockAttemptTimeoutStrategy(unittest.TestCase):
56 407339d0 Michael Hanselmann
  def testConstants(self):
57 a7770f03 Michael Hanselmann
    tpa = mcpu.LockAttemptTimeoutStrategy._TIMEOUT_PER_ATTEMPT
58 d385a174 Iustin Pop
    self.assert_(len(tpa) > LOCK_ATTEMPTS_TIMEOUT / LOCK_ATTEMPTS_MAXWAIT)
59 d385a174 Iustin Pop
    self.assert_(sum(tpa) >= LOCK_ATTEMPTS_TIMEOUT)
60 407339d0 Michael Hanselmann
61 0b04b188 Michael Hanselmann
    self.assertTrue(LOCK_ATTEMPTS_TIMEOUT >= 1800,
62 0b04b188 Michael Hanselmann
                    msg="Waiting less than half an hour per priority")
63 0b04b188 Michael Hanselmann
    self.assertTrue(LOCK_ATTEMPTS_TIMEOUT <= 3600,
64 0b04b188 Michael Hanselmann
                    msg="Waiting more than an hour per priority")
65 0b04b188 Michael Hanselmann
66 407339d0 Michael Hanselmann
  def testSimple(self):
67 a7770f03 Michael Hanselmann
    strat = mcpu.LockAttemptTimeoutStrategy(_random_fn=lambda: 0.5,
68 a7770f03 Michael Hanselmann
                                            _time_fn=lambda: 0.0)
69 407339d0 Michael Hanselmann
70 407339d0 Michael Hanselmann
    prev = None
71 a7770f03 Michael Hanselmann
    for i in range(len(strat._TIMEOUT_PER_ATTEMPT)):
72 a7770f03 Michael Hanselmann
      timeout = strat.NextAttempt()
73 407339d0 Michael Hanselmann
      self.assert_(timeout is not None)
74 407339d0 Michael Hanselmann
75 d385a174 Iustin Pop
      self.assert_(timeout <= LOCK_ATTEMPTS_MAXWAIT)
76 d385a174 Iustin Pop
      self.assert_(timeout >= LOCK_ATTEMPTS_MINWAIT)
77 407339d0 Michael Hanselmann
      self.assert_(prev is None or timeout >= prev)
78 407339d0 Michael Hanselmann
79 407339d0 Michael Hanselmann
      prev = timeout
80 407339d0 Michael Hanselmann
81 a6db1af2 Michael Hanselmann
    for _ in range(10):
82 a7770f03 Michael Hanselmann
      self.assert_(strat.NextAttempt() is None)
83 407339d0 Michael Hanselmann
84 407339d0 Michael Hanselmann
85 0a31dda0 Michael Hanselmann
class TestDispatchTable(unittest.TestCase):
86 0a31dda0 Michael Hanselmann
  def test(self):
87 0a31dda0 Michael Hanselmann
    for opcls in opcodes.OP_MAPPING.values():
88 687c10d9 Iustin Pop
      if not opcls.WITH_LU:
89 0a31dda0 Michael Hanselmann
        continue
90 687c10d9 Iustin Pop
      self.assertTrue(opcls in mcpu.Processor.DISPATCH_TABLE,
91 687c10d9 Iustin Pop
                      msg="%s missing handler class" % opcls)
92 0a31dda0 Michael Hanselmann
93 c9c33a28 Michael Hanselmann
      # Check against BGL whitelist
94 c9c33a28 Michael Hanselmann
      lucls = mcpu.Processor.DISPATCH_TABLE[opcls]
95 c9c33a28 Michael Hanselmann
      if lucls.REQ_BGL:
96 c9c33a28 Michael Hanselmann
        self.assertTrue(opcls in REQ_BGL_WHITELIST,
97 c9c33a28 Michael Hanselmann
                        msg=("%s not whitelisted for BGL" % opcls.OP_ID))
98 c9c33a28 Michael Hanselmann
      else:
99 c9c33a28 Michael Hanselmann
        self.assertFalse(opcls in REQ_BGL_WHITELIST,
100 c9c33a28 Michael Hanselmann
                         msg=("%s whitelisted for BGL, but doesn't use it" %
101 c9c33a28 Michael Hanselmann
                              opcls.OP_ID))
102 c9c33a28 Michael Hanselmann
103 0a31dda0 Michael Hanselmann
104 07923a3c Michael Hanselmann
class TestProcessResult(unittest.TestCase):
105 07923a3c Michael Hanselmann
  def setUp(self):
106 07923a3c Michael Hanselmann
    self._submitted = []
107 07923a3c Michael Hanselmann
    self._count = itertools.count(200)
108 07923a3c Michael Hanselmann
109 07923a3c Michael Hanselmann
  def _Submit(self, jobs):
110 07923a3c Michael Hanselmann
    job_ids = [self._count.next() for _ in jobs]
111 07923a3c Michael Hanselmann
    self._submitted.extend(zip(job_ids, jobs))
112 07923a3c Michael Hanselmann
    return job_ids
113 07923a3c Michael Hanselmann
114 07923a3c Michael Hanselmann
  def testNoJobs(self):
115 07923a3c Michael Hanselmann
    for i in [object(), [], False, True, None, 1, 929, {}]:
116 07923a3c Michael Hanselmann
      self.assertEqual(mcpu._ProcessResult(NotImplemented, NotImplemented, i),
117 07923a3c Michael Hanselmann
                       i)
118 07923a3c Michael Hanselmann
119 07923a3c Michael Hanselmann
  def testDefaults(self):
120 07923a3c Michael Hanselmann
    src = opcodes.OpTestDummy()
121 07923a3c Michael Hanselmann
122 07923a3c Michael Hanselmann
    res = mcpu._ProcessResult(self._Submit, src, cmdlib.ResultWithJobs([[
123 07923a3c Michael Hanselmann
      opcodes.OpTestDelay(),
124 07923a3c Michael Hanselmann
      opcodes.OpTestDelay(),
125 07923a3c Michael Hanselmann
      ], [
126 07923a3c Michael Hanselmann
      opcodes.OpTestDelay(),
127 07923a3c Michael Hanselmann
      ]]))
128 07923a3c Michael Hanselmann
129 07923a3c Michael Hanselmann
    self.assertEqual(res, {
130 07923a3c Michael Hanselmann
      constants.JOB_IDS_KEY: [200, 201],
131 07923a3c Michael Hanselmann
      })
132 07923a3c Michael Hanselmann
133 07923a3c Michael Hanselmann
    (_, (op1, op2)) = self._submitted.pop(0)
134 07923a3c Michael Hanselmann
    (_, (op3, )) = self._submitted.pop(0)
135 07923a3c Michael Hanselmann
    self.assertRaises(IndexError, self._submitted.pop)
136 07923a3c Michael Hanselmann
137 07923a3c Michael Hanselmann
    for op in [op1, op2, op3]:
138 07923a3c Michael Hanselmann
      self.assertTrue("OP_TEST_DUMMY" in op.comment)
139 07923a3c Michael Hanselmann
140 07923a3c Michael Hanselmann
  def testParams(self):
141 07923a3c Michael Hanselmann
    src = opcodes.OpTestDummy(priority=constants.OP_PRIO_HIGH,
142 07923a3c Michael Hanselmann
                              debug_level=3)
143 07923a3c Michael Hanselmann
144 07923a3c Michael Hanselmann
    res = mcpu._ProcessResult(self._Submit, src, cmdlib.ResultWithJobs([[
145 07923a3c Michael Hanselmann
      opcodes.OpTestDelay(priority=constants.OP_PRIO_LOW),
146 07923a3c Michael Hanselmann
      ], [
147 07923a3c Michael Hanselmann
      opcodes.OpTestDelay(comment="foobar", debug_level=10),
148 07923a3c Michael Hanselmann
      ]], other=True, value=range(10)))
149 07923a3c Michael Hanselmann
150 07923a3c Michael Hanselmann
    self.assertEqual(res, {
151 07923a3c Michael Hanselmann
      constants.JOB_IDS_KEY: [200, 201],
152 07923a3c Michael Hanselmann
      "other": True,
153 07923a3c Michael Hanselmann
      "value": range(10),
154 07923a3c Michael Hanselmann
      })
155 07923a3c Michael Hanselmann
156 07923a3c Michael Hanselmann
    (_, (op1, )) = self._submitted.pop(0)
157 07923a3c Michael Hanselmann
    (_, (op2, )) = self._submitted.pop(0)
158 07923a3c Michael Hanselmann
    self.assertRaises(IndexError, self._submitted.pop)
159 07923a3c Michael Hanselmann
160 07923a3c Michael Hanselmann
    self.assertEqual(op1.priority, constants.OP_PRIO_LOW)
161 07923a3c Michael Hanselmann
    self.assertTrue("OP_TEST_DUMMY" in op1.comment)
162 07923a3c Michael Hanselmann
    self.assertEqual(op1.debug_level, 3)
163 07923a3c Michael Hanselmann
164 a9e1819b Klaus Aehlig
    # FIXME: as priority is mandatory, there is no way
165 a9e1819b Klaus Aehlig
    # of specifying "just inherit the priority".
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()