~abentley/juju-ci-tools/client-from-config-4

« back to all changes in this revision

Viewing changes to tests/test_quickstart_deploy.py

  • Committer: Aaron Bentley
  • Date: 2014-02-24 17:18:29 UTC
  • mto: This revision was merged to the branch mainline in revision 252.
  • Revision ID: aaron.bentley@canonical.com-20140224171829-sz644yhoygu7m9dm
Use tags to identify and shut down instances.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
from mock import (
2
 
    ANY,
3
 
    MagicMock,
4
 
    patch,
5
 
)
6
 
 
7
 
from deploy_stack import BootstrapManager
8
 
from jujupy import (
9
 
    EnvJujuClient,
10
 
    JujuData,
11
 
    )
12
 
from quickstart_deploy import QuickstartTest
13
 
from tests import (
14
 
    FakeHomeTestCase,
15
 
    use_context,
16
 
)
17
 
from tests.test_deploy_stack import FakeBootstrapManager
18
 
from tests.test_jujupy import fake_juju_client
19
 
from utility import temp_dir
20
 
 
21
 
 
22
 
def make_bootstrap_manager(client, log_dir='log_dir'):
23
 
    return BootstrapManager(
24
 
        'env', client, client, None, [], 'series', 'agent_url',
25
 
        'agent_stream', 'region', log_dir, 'keep_env', 'permanent',
26
 
        'jes_enabled')
27
 
 
28
 
 
29
 
class TestQuickstartTest(FakeHomeTestCase):
30
 
 
31
 
    def test_run_finally(self):
32
 
        do_finally = MagicMock()
33
 
 
34
 
        def fake_iter_steps():
35
 
            try:
36
 
                yield {'bootstrap_host': 'foo'}
37
 
            finally:
38
 
                do_finally()
39
 
 
40
 
        client = EnvJujuClient(
41
 
            JujuData('foo', {'type': 'local'}), '1.234-76', None)
42
 
        bs_manager = make_bootstrap_manager(client)
43
 
        quickstart = QuickstartTest(bs_manager, '/tmp/bundle.yaml', 2)
44
 
        with patch.object(quickstart, 'iter_steps',
45
 
                          side_effect=fake_iter_steps):
46
 
            quickstart.run()
47
 
        do_finally.assert_called_once_with()
48
 
 
49
 
    def test_run_exception(self):
50
 
        tear_down = MagicMock()
51
 
 
52
 
        def fake_iter_steps():
53
 
            try:
54
 
                yield {'bootstrap_host': 'foo'}
55
 
            except:
56
 
                tear_down()
57
 
 
58
 
        client = EnvJujuClient(
59
 
            JujuData('foo', {'type': 'local'}), '1.234-76', None)
60
 
        bs_manager = make_bootstrap_manager(client)
61
 
        quickstart = QuickstartTest(bs_manager, '/tmp/bundle.yaml', 2)
62
 
        with patch.object(quickstart, 'iter_steps',
63
 
                          side_effect=fake_iter_steps):
64
 
            with self.assertRaises(BaseException):
65
 
                with patch('logging.info', side_effect=Exception):
66
 
                    quickstart.run()
67
 
        tear_down.assert_called_once_with()
68
 
 
69
 
    def test_iter_steps(self):
70
 
        log_dir = use_context(self, temp_dir())
71
 
        client = EnvJujuClient(
72
 
            JujuData('foo', {'type': 'local'}), '1.234-76', None)
73
 
        bs_manager = make_bootstrap_manager(client, log_dir=log_dir)
74
 
        quickstart = QuickstartTest(bs_manager, '/tmp/bundle.yaml', 2)
75
 
        steps = quickstart.iter_steps()
76
 
        with patch.object(client, 'quickstart') as qs_mock:
77
 
            # Test first yield
78
 
            with patch('jujupy.check_free_disk_space', autospec=True):
79
 
                with patch('deploy_stack.tear_down', autospec=True) as td_mock:
80
 
                    step = steps.next()
81
 
        td_mock.assert_called_once_with(client, 'jes_enabled', try_jes=True)
82
 
        qs_mock.assert_called_once_with('/tmp/bundle.yaml')
83
 
        expected = {'juju-quickstart': 'Returned from quickstart'}
84
 
        self.assertEqual(expected, step)
85
 
        with patch('deploy_stack.get_machine_dns_name',
86
 
                   return_value='mocked_name') as dns_mock:
87
 
            # Test second yield
88
 
            with patch.object(client, 'get_controller_client') as gcc_mock:
89
 
                step = steps.next()
90
 
        dns_mock.assert_called_once_with(gcc_mock.return_value, '0')
91
 
        self.assertEqual('mocked_name', step['bootstrap_host'])
92
 
        with patch.object(client, 'wait_for_deploy_started') as wds_mock:
93
 
            # Test third yield
94
 
            step = steps.next()
95
 
        wds_mock.assert_called_once_with(2)
96
 
        self.assertEqual('Deploy stated', step['deploy_started'])
97
 
        with patch.object(client, 'wait_for_started') as ws_mock:
98
 
            # Test forth yield
99
 
            step = steps.next()
100
 
        ws_mock.assert_called_once_with(ANY)
101
 
        self.assertEqual('All Agents started', step['agents_started'])
102
 
        with patch('deploy_stack.safe_print_status'):
103
 
            with patch('deploy_stack.tear_down'):
104
 
                with patch('quickstart_deploy.BootstrapManager.dump_all_logs'):
105
 
                    with patch('jujupy.EnvJujuClient.iter_model_clients',
106
 
                               return_value=[]):
107
 
                        steps.close()
108
 
 
109
 
    def test_iter_steps_context(self):
110
 
        client = fake_juju_client()
111
 
        bs_manager = FakeBootstrapManager(client)
112
 
        quickstart = QuickstartTest(bs_manager, '/tmp/bundle.yaml', 2)
113
 
        step_iter = quickstart.iter_steps()
114
 
        self.assertIs(False, bs_manager.entered_top)
115
 
        self.assertIs(False, bs_manager.exited_top)
116
 
        self.assertIs(False, bs_manager.entered_bootstrap)
117
 
        self.assertIs(False, bs_manager.exited_bootstrap)
118
 
        step_iter.next()
119
 
        models = client._backend.controller_state.models
120
 
        backing_state = models[client.model_name]
121
 
        self.assertEqual('/tmp/bundle.yaml', backing_state.current_bundle)
122
 
        self.assertIs(True, bs_manager.entered_top)
123
 
        self.assertIs(True, bs_manager.entered_bootstrap)
124
 
        self.assertIs(False, bs_manager.exited_bootstrap)
125
 
        self.assertIs(False, bs_manager.entered_runtime)
126
 
        self.assertIs(False, bs_manager.exited_runtime)
127
 
        step_iter.next()
128
 
        self.assertIs(True, bs_manager.exited_bootstrap)
129
 
        self.assertIs(True, bs_manager.entered_runtime)
130
 
        self.assertIs(False, bs_manager.exited_runtime)
131
 
        with patch.object(client, 'wait_for_deploy_started') as wfds_mock:
132
 
            step_iter.next()
133
 
        wfds_mock.assert_called_once_with(2)
134
 
        self.assertIs(False, bs_manager.exited_runtime)
135
 
        with patch.object(client, 'wait_for_started') as wfs_mock:
136
 
            step_iter.next()
137
 
        wfs_mock.assert_called_once_with(3600)
138
 
        self.assertIs(False, bs_manager.exited_runtime)
139
 
        with self.assertRaises(StopIteration):
140
 
            step_iter.next()
141
 
        self.assertIs(True, bs_manager.exited_runtime)
142
 
        self.assertIs(True, bs_manager.exited_top)
143
 
 
144
 
    def test_iter_steps_quickstart_fail(self):
145
 
        client = EnvJujuClient(
146
 
            JujuData('foo', {'type': 'local'}), '1.234-76', None)
147
 
        bs_manager = FakeBootstrapManager(client)
148
 
        quickstart = QuickstartTest(bs_manager, '/tmp/bundle.yaml', 2)
149
 
        step_iter = quickstart.iter_steps()
150
 
        with patch.object(client, 'quickstart', side_effect=Exception):
151
 
            with self.assertRaises(Exception):
152
 
                step_iter.next()
153
 
        self.assertIs(False, bs_manager.entered_runtime)
154
 
        self.assertIs(True, bs_manager.exited_bootstrap)
155
 
        self.assertIs(True, bs_manager.exited_top)
156
 
 
157
 
    def test_iter_steps_wait_fail(self):
158
 
        client = fake_juju_client()
159
 
        bs_manager = FakeBootstrapManager(client)
160
 
        quickstart = QuickstartTest(bs_manager, '/tmp/bundle.yaml', 2)
161
 
        step_iter = quickstart.iter_steps()
162
 
        step_iter.next()
163
 
        step_iter.next()
164
 
        with patch.object(client, 'wait_for_deploy_started',
165
 
                          side_effect=Exception):
166
 
            with self.assertRaises(Exception):
167
 
                step_iter.next()
168
 
        self.assertIs(True, bs_manager.exited_runtime)
169
 
        self.assertIs(True, bs_manager.exited_bootstrap)
170
 
        self.assertIs(True, bs_manager.exited_top)