blob: 492bdca89807bd6c17e44a3b450c6438969c1bed [file] [log] [blame]
Matthew Treinish7b015822014-01-21 18:15:39 +00001# Copyright 2014 IBM Corp.
2#
3# Licensed under the Apache License, Version 2.0 (the "License"); you may
4# not use this file except in compliance with the License. You may obtain
5# a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12# License for the specific language governing permissions and limitations
13# under the License.
14
15import time
16
17import mock
18
19from tempest.common import waiters
20from tempest import exceptions
Yaroslav Lobankovdb4a2e12015-11-28 20:04:54 +030021from tempest.services.volume.base import base_volumes_client
Matthew Treinish7b015822014-01-21 18:15:39 +000022from tempest.tests import base
Jordan Pittier0e53b612016-03-03 14:23:17 +010023import tempest.tests.utils as utils
Matthew Treinish7b015822014-01-21 18:15:39 +000024
25
26class TestImageWaiters(base.TestCase):
27 def setUp(self):
28 super(TestImageWaiters, self).setUp()
29 self.client = mock.MagicMock()
30 self.client.build_timeout = 1
31 self.client.build_interval = 1
32
33 def test_wait_for_image_status(self):
Ken'ichi Ohmichi5d410762015-05-22 01:10:03 +000034 self.client.show_image.return_value = ({'status': 'active'})
Matthew Treinish7b015822014-01-21 18:15:39 +000035 start_time = int(time.time())
36 waiters.wait_for_image_status(self.client, 'fake_image_id', 'active')
37 end_time = int(time.time())
38 # Ensure waiter returns before build_timeout
39 self.assertTrue((end_time - start_time) < 10)
40
Jordan Pittier0e53b612016-03-03 14:23:17 +010041 @mock.patch('time.sleep')
42 def test_wait_for_image_status_timeout(self, mock_sleep):
43 time_mock = self.patch('time.time')
44 time_mock.side_effect = utils.generate_timeout_series(1)
45
Ken'ichi Ohmichi5d410762015-05-22 01:10:03 +000046 self.client.show_image.return_value = ({'status': 'saving'})
Matthew Treinish7b015822014-01-21 18:15:39 +000047 self.assertRaises(exceptions.TimeoutException,
48 waiters.wait_for_image_status,
49 self.client, 'fake_image_id', 'active')
Jordan Pittier0e53b612016-03-03 14:23:17 +010050 mock_sleep.assert_called_once_with(1)
Matthew Treinish7b015822014-01-21 18:15:39 +000051
Jordan Pittier0e53b612016-03-03 14:23:17 +010052 @mock.patch('time.sleep')
53 def test_wait_for_image_status_error_on_image_create(self, mock_sleep):
Ken'ichi Ohmichi5d410762015-05-22 01:10:03 +000054 self.client.show_image.return_value = ({'status': 'ERROR'})
Matthew Treinish7b015822014-01-21 18:15:39 +000055 self.assertRaises(exceptions.AddImageException,
56 waiters.wait_for_image_status,
57 self.client, 'fake_image_id', 'active')
Jordan Pittier0e53b612016-03-03 14:23:17 +010058 mock_sleep.assert_called_once_with(1)
Matt Riedemannf77e7dc2015-08-10 16:39:39 -070059
60 @mock.patch.object(time, 'sleep')
61 def test_wait_for_volume_status_error_restoring(self, mock_sleep):
62 # Tests that the wait method raises VolumeRestoreErrorException if
63 # the volume status is 'error_restoring'.
Yaroslav Lobankovdb4a2e12015-11-28 20:04:54 +030064 client = mock.Mock(spec=base_volumes_client.BaseVolumesClient,
Matt Riedemannf77e7dc2015-08-10 16:39:39 -070065 build_interval=1)
John Warren6177c9e2015-08-19 20:00:17 +000066 volume1 = {'volume': {'status': 'restoring-backup'}}
67 volume2 = {'volume': {'status': 'error_restoring'}}
Matt Riedemannf77e7dc2015-08-10 16:39:39 -070068 mock_show = mock.Mock(side_effect=(volume1, volume2))
69 client.show_volume = mock_show
70 volume_id = '7532b91e-aa0a-4e06-b3e5-20c0c5ee1caa'
71 self.assertRaises(exceptions.VolumeRestoreErrorException,
72 waiters.wait_for_volume_status,
73 client, volume_id, 'available')
74 mock_show.assert_has_calls([mock.call(volume_id),
75 mock.call(volume_id)])
76 mock_sleep.assert_called_once_with(1)