You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
140 lines
5.3 KiB
140 lines
5.3 KiB
#!/usr/bin/python2
|
|
#
|
|
# Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
# found in the LICENSE file.
|
|
|
|
"""Unit tests for server/cros/host_lock_manager.py."""
|
|
import mock
|
|
import unittest
|
|
import common
|
|
|
|
from autotest_lib.server.cros import host_lock_manager
|
|
from autotest_lib.server.cros.chaos_lib import chaos_datastore_utils
|
|
|
|
|
|
class HostLockManagerTest(unittest.TestCase):
|
|
"""Unit tests for host_lock_manager.HostLockManager.
|
|
|
|
@attribute HOST1: a string, fake host.
|
|
@attribute HOST2: a string, fake host.
|
|
@attribute HOST3: a string, fake host.
|
|
"""
|
|
|
|
HOST1 = 'host1'
|
|
HOST2 = 'host2'
|
|
HOST3 = 'host3'
|
|
|
|
|
|
class MockHostLockManager(host_lock_manager.HostLockManager):
|
|
"""Mock out _host_modifier() in HostLockManager class..
|
|
|
|
@attribute locked: a boolean, True == host is locked.
|
|
@attribute locked_by: a string, fake user.
|
|
@attribute lock_time: a string, fake timestamp.
|
|
"""
|
|
|
|
def _host_modifier(self, hosts, operation, lock_reason=''):
|
|
"""Overwrites original _host_modifier().
|
|
|
|
Add hosts to self.locked_hosts for LOCK and remove hosts from
|
|
self.locked_hosts for UNLOCK.
|
|
|
|
@param a set of strings, host names.
|
|
@param operation: a string, LOCK or UNLOCK.
|
|
@param lock_reason: a string, a reason for locking the hosts
|
|
"""
|
|
if operation == self.LOCK:
|
|
assert lock_reason
|
|
self.locked_hosts = self.locked_hosts.union(hosts)
|
|
elif operation == self.UNLOCK:
|
|
self.locked_hosts = self.locked_hosts.difference(hosts)
|
|
|
|
|
|
def setUp(self):
|
|
super(HostLockManagerTest, self).setUp()
|
|
self.manager = host_lock_manager.HostLockManager()
|
|
|
|
|
|
# Patch mock object to return host as unknown from DataStore
|
|
@mock.patch.object(chaos_datastore_utils.ChaosDataStoreUtils, 'show_device',
|
|
return_value=False)
|
|
def testCheckHost_SkipsUnknownHost(self, get_mock):
|
|
actual = self.manager._check_host('host1', None)
|
|
self.assertEquals(None, actual)
|
|
|
|
|
|
@mock.patch.object(chaos_datastore_utils.ChaosDataStoreUtils, 'show_device',
|
|
return_value={'lock_status': True, 'locked_by': 'Mock',
|
|
'lock_status_updated': 'fake_time'})
|
|
def testCheckHost_DetectsLockedHost(self, get_mock):
|
|
"""Test that a host which is already locked is skipped."""
|
|
actual = self.manager._check_host(self.HOST1, self.manager.LOCK)
|
|
self.assertEquals(None, actual)
|
|
|
|
|
|
@mock.patch.object(chaos_datastore_utils.ChaosDataStoreUtils, 'show_device',
|
|
return_value={'lock_status': False, 'locked_by': 'Mock',
|
|
'lock_status_updated': 'fake_time'})
|
|
def testCheckHost_DetectsUnlockedHost(self, get_mock):
|
|
"""Test that a host which is already unlocked is skipped."""
|
|
actual = self.manager._check_host(self.HOST1, self.manager.UNLOCK)
|
|
self.assertEquals(None, actual)
|
|
|
|
|
|
@mock.patch.object(chaos_datastore_utils.ChaosDataStoreUtils, 'show_device',
|
|
return_value={'lock_status': False, 'locked_by': 'Mock',
|
|
'lock_status_updated': 'fake_time'})
|
|
def testCheckHost_ReturnsHostToLock(self, get_mock):
|
|
"""Test that a host which can be locked is returned."""
|
|
actual = self.manager._check_host(self.HOST1, self.manager.LOCK)
|
|
self.assertEquals(self.HOST1, actual)
|
|
|
|
|
|
@mock.patch.object(chaos_datastore_utils.ChaosDataStoreUtils, 'show_device',
|
|
return_value={'lock_status': True, 'locked_by': 'Mock',
|
|
'lock_status_updated': 'fake_time'})
|
|
def testCheckHost_ReturnsHostToUnlock(self, get_mock):
|
|
"""Test that a host which can be unlocked is returned."""
|
|
actual = self.manager._check_host(self.HOST1, self.manager.UNLOCK)
|
|
self.assertEquals(self.HOST1, actual)
|
|
|
|
|
|
def testLock_WithNonOverlappingHosts(self):
|
|
"""Tests host locking, all hosts not in self.locked_hosts."""
|
|
hosts = [self.HOST2]
|
|
manager = self.MockHostLockManager()
|
|
manager.locked_hosts = set([self.HOST1])
|
|
manager.lock(hosts, lock_reason='Locking for test')
|
|
self.assertEquals(set([self.HOST1, self.HOST2]), manager.locked_hosts)
|
|
|
|
|
|
def testLock_WithPartialOverlappingHosts(self):
|
|
"""Tests host locking, some hosts not in self.locked_hosts."""
|
|
hosts = [self.HOST1, self.HOST2]
|
|
manager = self.MockHostLockManager()
|
|
manager.locked_hosts = set([self.HOST1, self.HOST3])
|
|
manager.lock(hosts, lock_reason='Locking for test')
|
|
self.assertEquals(set([self.HOST1, self.HOST2, self.HOST3]),
|
|
manager.locked_hosts)
|
|
|
|
|
|
def testLock_WithFullyOverlappingHosts(self):
|
|
"""Tests host locking, all hosts in self.locked_hosts."""
|
|
hosts = [self.HOST1, self.HOST2]
|
|
self.manager.locked_hosts = set(hosts)
|
|
self.manager.lock(hosts)
|
|
self.assertEquals(set(hosts), self.manager.locked_hosts)
|
|
|
|
|
|
def testUnlock_WithNonOverlappingHosts(self):
|
|
"""Tests host unlocking, all hosts not in self.locked_hosts."""
|
|
hosts = [self.HOST2]
|
|
self.manager.locked_hosts = set([self.HOST1])
|
|
self.manager.unlock(hosts)
|
|
self.assertEquals(set([self.HOST1]), self.manager.locked_hosts)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|