Dan Shi | 25e1fd4 | 2014-12-19 14:36:42 -0800 | [diff] [blame] | 1 | # pylint: disable-msg=C0111 |
Jakob Juelich | 8b110ee | 2014-09-15 16:13:42 -0700 | [diff] [blame] | 2 | #!/usr/bin/python |
| 3 | # |
| 4 | # Copyright 2008 Google Inc. All Rights Reserved. |
| 5 | |
| 6 | """Tests for shard.""" |
| 7 | |
Dan Shi | 25e1fd4 | 2014-12-19 14:36:42 -0800 | [diff] [blame] | 8 | import unittest |
Jakob Juelich | 8b110ee | 2014-09-15 16:13:42 -0700 | [diff] [blame] | 9 | |
| 10 | import common |
Dan Shi | 25e1fd4 | 2014-12-19 14:36:42 -0800 | [diff] [blame] | 11 | from autotest_lib.cli import cli_mock |
Jakob Juelich | 8b110ee | 2014-09-15 16:13:42 -0700 | [diff] [blame] | 12 | |
| 13 | |
| 14 | class shard_list_unittest(cli_mock.cli_unittest): |
| 15 | values = [{'hostname': u'shard1', u'id': 1, 'labels': ['board:lumpy']}, |
| 16 | {'hostname': u'shard2', u'id': 3, 'labels': ['board:daisy']}, |
| 17 | {'hostname': u'shard3', u'id': 5, 'labels': ['board:stumpy']}, |
| 18 | {'hostname': u'shard4', u'id': 6, 'labels': ['board:link']}] |
| 19 | |
| 20 | |
| 21 | def test_shard_list(self): |
| 22 | self.run_cmd(argv=['atest', 'shard', 'list'], |
| 23 | rpcs=[('get_shards', {}, True, self.values)], |
| 24 | out_words_ok=['shard1', 'shard2', 'shard3', 'shard4'], |
| 25 | out_words_no=['plat0', 'plat1']) |
| 26 | |
| 27 | |
| 28 | class shard_create_unittest(cli_mock.cli_unittest): |
| 29 | def test_execute_create_two_shards(self): |
| 30 | self.run_cmd(argv=['atest', 'shard', 'create', |
| 31 | '-l', 'board:lumpy', 'shard0'], |
| 32 | rpcs=[('add_shard', |
MK Ryu | 5dfcc89 | 2015-07-16 15:34:04 -0700 | [diff] [blame] | 33 | {'hostname': 'shard0', 'labels': 'board:lumpy'}, |
Jakob Juelich | 8b110ee | 2014-09-15 16:13:42 -0700 | [diff] [blame] | 34 | True, 42)], |
| 35 | out_words_ok=['Created', 'shard0']) |
| 36 | |
| 37 | |
| 38 | def test_execute_create_two_shards_bad(self): |
| 39 | self.run_cmd(argv=['atest', 'shard', 'create', |
| 40 | '-l', 'board:lumpy', 'shard0'], |
| 41 | rpcs=[('add_shard', |
MK Ryu | 5dfcc89 | 2015-07-16 15:34:04 -0700 | [diff] [blame] | 42 | {'hostname': 'shard0', 'labels': 'board:lumpy'}, |
Jakob Juelich | 8b110ee | 2014-09-15 16:13:42 -0700 | [diff] [blame] | 43 | False, |
| 44 | '''ValidationError: {'name': |
| 45 | 'This value must be unique (shard1)'}''')], |
| 46 | out_words_no=['shard0'], |
| 47 | err_words_ok=['shard0', 'ValidationError']) |
| 48 | |
| 49 | |
Shuqian Zhao | b8b13d8 | 2016-08-04 09:35:17 -0700 | [diff] [blame] | 50 | class shard_add_boards_unittest(cli_mock.cli_unittest): |
| 51 | def test_execute_add_boards_to_shard(self): |
| 52 | self.run_cmd(argv=['atest', 'shard', 'add_boards', |
| 53 | '-l', 'board:lumpy', 'shard0'], |
| 54 | rpcs=[('add_board_to_shard', |
| 55 | {'hostname': 'shard0', 'labels':'board:lumpy'}, |
| 56 | True, 42)], |
| 57 | out_words_ok=['Added boards', 'board:lumpy', 'shard0']) |
| 58 | |
| 59 | |
| 60 | def test_execute_add_boards_to_shard_bad(self): |
| 61 | self.run_cmd(argv=['atest', 'shard', 'add_boards', |
| 62 | '-l', 'board:lumpy', 'shard0'], |
| 63 | rpcs=[('add_board_to_shard', |
| 64 | {'hostname': 'shard0', 'labels':'board:lumpy'}, |
| 65 | False, |
| 66 | '''RPCException: board:lumpy is already on shard |
| 67 | shard0''')], |
| 68 | out_words_no=['shard0'], |
| 69 | err_words_ok=['shard0', 'RPCException']) |
| 70 | |
| 71 | |
| 72 | def test_execute_add_boards_to_shard_fail_when_shard_nonexist(self): |
| 73 | self.run_cmd(argv=['atest', 'shard', 'add_boards', |
| 74 | '-l', 'board:lumpy', 'shard0'], |
| 75 | rpcs=[('add_board_to_shard', |
| 76 | {'hostname': 'shard0', 'labels':'board:lumpy'}, |
| 77 | False, |
| 78 | '''DoesNotExist: Shard matching query does not |
| 79 | exist. Lookup parameters were {'hostname': |
| 80 | 'shard0'}''')], |
| 81 | out_words_no=['shard0'], |
| 82 | err_words_ok=['shard0', 'DoesNotExist:']) |
| 83 | |
| 84 | |
Jakob Juelich | 8b110ee | 2014-09-15 16:13:42 -0700 | [diff] [blame] | 85 | class shard_delete_unittest(cli_mock.cli_unittest): |
| 86 | def test_execute_delete_shards(self): |
| 87 | self.run_cmd(argv=['atest', 'shard', 'delete', |
Dan Shi | 25e1fd4 | 2014-12-19 14:36:42 -0800 | [diff] [blame] | 88 | 'shard0', 'shard1', '--no-confirmation'], |
Jakob Juelich | 8b110ee | 2014-09-15 16:13:42 -0700 | [diff] [blame] | 89 | rpcs=[('delete_shard', {'hostname': 'shard0'}, True, None), |
| 90 | ('delete_shard', {'hostname': 'shard1'}, True, None) |
| 91 | ], |
| 92 | out_words_ok=['Deleted', 'shard0', 'shard1']) |
| 93 | |
| 94 | |
Jakob Juelich | 8b110ee | 2014-09-15 16:13:42 -0700 | [diff] [blame] | 95 | if __name__ == '__main__': |
| 96 | unittest.main() |