Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / helpdesk / tests.py @ 468ba00b

History | View | Annotate | Download (11.5 kB)

1
# Copyright 2011 GRNET S.A. All rights reserved.
2
#
3
# Redistribution and use in source and binary forms, with or
4
# without modification, are permitted provided that the following
5
# conditions are met:
6
#
7
#   1. Redistributions of source code must retain the above
8
#      copyright notice, this list of conditions and the following
9
#      disclaimer.
10
#
11
#   2. Redistributions in binary form must reproduce the above
12
#      copyright notice, this list of conditions and the following
13
#      disclaimer in the documentation and/or other materials
14
#      provided with the distribution.
15
#
16
# THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
17
# OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
20
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
23
# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
24
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27
# POSSIBILITY OF SUCH DAMAGE.
28
#
29
# The views and conclusions contained in the software and
30
# documentation are those of the authors and should not be
31
# interpreted as representing official policies, either expressed
32
# or implied, of GRNET S.A.
33
#
34

    
35
import mock
36

    
37
from django.test import TestCase, Client
38
from django.conf import settings
39
from django.core.urlresolvers import reverse
40

    
41

    
42
USER1 = "5edcb5aa-1111-4146-a8ed-2b6287824353"
43
USER2 = "5edcb5aa-2222-4146-a8ed-2b6287824353"
44

    
45
USERS_UUIDS = {}
46
USERS_UUIDS[USER1] = {'displayname': 'testuser@test.com'}
47
USERS_UUIDS[USER2] = {'displayname': 'testuser2@test.com'}
48

    
49
USERS_DISPLAYNAMES = dict(map(lambda k: (k[1]['displayname'], {'uuid': k[0]}),
50
                          USERS_UUIDS.iteritems()))
51

    
52
from synnefo.db import models_factory as mfactory
53

    
54

    
55
class AstakosClientMock():
56
    def __init__(*args, **kwargs):
57
        pass
58

    
59
    def get_username(self, token, uuid):
60
        try:
61
            return USERS_UUIDS.get(uuid)['displayname']
62
        except TypeError:
63
            return None
64

    
65
    def get_uuid(self, token, display_name):
66
        try:
67
            return USERS_DISPLAYNAMES.get(display_name)['uuid']
68
        except TypeError:
69
            return None
70

    
71

    
72
class AuthClient(Client):
73

    
74
    def request(self, **request):
75
        token = request.pop('user_token', '0000')
76
        if token:
77
            request['HTTP_X_AUTH_TOKEN'] = token
78
        return super(AuthClient, self).request(**request)
79

    
80

    
81
class HelpdeskTests(TestCase):
82
    """
83
    Helpdesk tests. Test correctness of permissions and returned data.
84
    """
85

    
86
    fixtures = ['helpdesk_test']
87

    
88
    def setUp(self):
89

    
90
        def get_user_mock(request, *args, **kwargs):
91
            if request.META.get('HTTP_X_AUTH_TOKEN', None) == '0000':
92
                request.user_uniq = 'test'
93
                request.user = {'uniq': 'test', 'auth_token': '0000'}
94
            if request.META.get('HTTP_X_AUTH_TOKEN', None) == '0001':
95
                request.user_uniq = 'test'
96
                request.user = {'uniq': 'test', 'groups': ['default',
97
                                                           'helpdesk'],
98
                                'auth_token': '0001'}
99

    
100
        # mock the astakos authentication function
101
        from snf_django.lib import astakos
102
        astakos.get_user = get_user_mock
103
        import astakosclient
104
        astakosclient.AstakosClient = AstakosClientMock
105

    
106
        settings.SKIP_SSH_VALIDATION = True
107
        settings.HELPDESK_ENABLED = True
108
        self.client = AuthClient()
109

    
110
    def test_enabled_setting(self):
111
        settings.HELPDESK_ENABLED = False
112

    
113
        # helpdesk is disabled
114
        r = self.client.get(reverse('helpdesk-index'), user_token="0001")
115
        self.assertEqual(r.status_code, 404)
116
        r = self.client.get(reverse('helpdesk-details',
117
                                    args=['testuser@test.com']),
118
                            user_token="0001")
119
        self.assertEqual(r.status_code, 404)
120

    
121
    def test_ip_lookup(self):
122
        # ip does not exist, proper message gets displayed
123
        r = self.client.get(reverse('helpdesk-details',
124
                            args=["195.251.221.122"]), user_token='0001')
125
        self.assertContains(r, 'User with IP')
126

    
127
        # ip exists, 'test' account discovered
128
        r = self.client.get(reverse('helpdesk-details',
129
                            args=["195.251.222.211"]), user_token='0001')
130
        self.assertEqual(r.context['account'], USER2)
131

    
132
    def test_vm_lookup(self):
133
        # vm id does not exist
134
        r = self.client.get(reverse('helpdesk-details',
135
                            args=["vm-123"]), user_token='0001')
136
        self.assertContains(r, 'User with Virtual Machine')
137

    
138
        # vm exists, 'test' account discovered
139
        r = self.client.get(reverse('helpdesk-details',
140
                            args=["vm1001"]), user_token='0001')
141
        self.assertEqual(r.context['account'], USER1)
142
        r = self.client.get(reverse('helpdesk-details',
143
                            args=["vm1002"]), user_token='0001')
144
        self.assertEqual(r.context['account'], USER2)
145
        # dash also works
146
        r = self.client.get(reverse('helpdesk-details',
147
                            args=["vm-1002"]), user_token='0001')
148
        self.assertEqual(r.context['account'], USER2)
149

    
150
    def test_view_permissions(self):
151
        # anonymous user gets 403
152
        r = self.client.get(reverse('helpdesk-index'), user_token=None)
153
        self.assertEqual(r.status_code, 403)
154
        r = self.client.get(reverse('helpdesk-details',
155
                                    args=['testuser@test.com']),
156
                            user_token=None)
157
        self.assertEqual(r.status_code, 403)
158

    
159
        # user not in helpdesk group gets 403
160
        r = self.client.get(reverse('helpdesk-index'))
161
        self.assertEqual(r.status_code, 403)
162
        r = self.client.get(reverse('helpdesk-details',
163
                                    args=['testuser@test.com']))
164
        self.assertEqual(r.status_code, 403)
165

    
166
        # user with helpdesk group gets 200
167
        r = self.client.get(reverse('helpdesk-index'), user_token="0001")
168
        self.assertEqual(r.status_code, 200)
169
        r = self.client.get(reverse('helpdesk-details',
170
                                    args=['testuser@test.com']),
171
                            user_token="0001")
172
        self.assertEqual(r.status_code, 200)
173

    
174
        r = self.client.post(reverse('helpdesk-suspend-vm', args=(1001,)))
175
        r = self.client.get(reverse('helpdesk-suspend-vm', args=(1001,)),
176
                            user_token="0001", data={'token': '1234'})
177
        self.assertEqual(r.status_code, 403)
178
        r = self.client.get(reverse('helpdesk-suspend-vm', args=(1001,)),
179
                            user_token="0001")
180
        self.assertEqual(r.status_code, 403)
181
        r = self.client.post(reverse('helpdesk-suspend-vm', args=(1001,)),
182
                             user_token="0001", data={'token': '0001'})
183
        self.assertEqual(r.status_code, 302)
184
        r = self.client.post(reverse('helpdesk-suspend-vm', args=(1001,)),
185
                             user_token="0000", data={'token': '0000'})
186
        self.assertEqual(r.status_code, 403)
187

    
188
    def test_suspend_vm(self):
189
        r = self.client.get(reverse('helpdesk-details',
190
                                    args=['testuser@test.com']),
191
                            user_token="0001")
192
        self.assertEqual(r.status_code, 200)
193
        vmid = r.context['vms'][0].pk
194
        r = self.client.post(reverse('helpdesk-suspend-vm', args=(vmid,)),
195
                             data={'token': '0001'}, user_token="0001")
196
        self.assertEqual(r.status_code, 302)
197

    
198
        r = self.client.get(reverse('helpdesk-details',
199
                                    args=['testuser@test.com']),
200
                            user_token="0001")
201
        self.assertTrue(r.context['vms'][0].suspended)
202

    
203
        r = self.client.post(reverse('helpdesk-suspend-vm-release',
204
                                     args=(vmid,)), data={'token': '0001'},
205
                             user_token="0001")
206
        self.assertEqual(r.status_code, 302)
207
        r = self.client.get(reverse('helpdesk-details',
208
                                    args=['testuser@test.com']),
209
                            user_token="0001")
210
        self.assertFalse(r.context['vms'][0].suspended)
211

    
212
    def test_results_get_filtered(self):
213
        """
214
        Test that view context data are filtered based on userid provided.
215
        Check helpdesk_test.json to see the existing database data.
216
        """
217

    
218
        # 'testuser@test.com' details, see
219
        # helpdes/fixtures/helpdesk_test.json for more details
220
        r = self.client.get(reverse('helpdesk-details',
221
                                    args=['testuser@test.com']),
222
                            user_token="0001")
223
        account = r.context['account']
224
        vms = r.context['vms']
225
        nets = r.context['networks']
226
        self.assertEqual(account, USER1)
227
        self.assertEqual(vms[0].name, "user1 vm")
228
        self.assertEqual(vms.count(), 1)
229
        self.assertEqual(len(nets), 1)
230
        self.assertEqual(r.context['account_exists'], True)
231

    
232
        # 'testuser2@test.com' details, see helpdesk
233
        # /fixtures/helpdesk_test.json for more details
234
        r = self.client.get(reverse('helpdesk-details',
235
                                    args=['testuser2@test.com']),
236
                            user_token="0001")
237
        account = r.context['account']
238
        vms = r.context['vms']
239
        nets = r.context['networks']
240
        self.assertEqual(account, USER2)
241
        self.assertEqual(vms[0].name, "user2 vm2")
242
        self.assertEqual(vms[1].name, "user2 vm1")
243
        self.assertEqual(vms.count(), 2)
244
        self.assertEqual(len(nets), 0)
245
        self.assertEqual(r.context['account_exists'], True)
246

    
247
        # 'testuser5@test.com' does not exist, should be redirected to
248
        # helpdesk home
249
        r = self.client.get(reverse('helpdesk-details',
250
                                    args=['testuser5@test.com']),
251
                            user_token="0001")
252
        vms = r.context['vms']
253
        self.assertEqual(r.context['account_exists'], False)
254
        self.assertEqual(vms.count(), 0)
255

    
256
    def test_start_shutdown(self):
257
        from synnefo.logic import backend
258

    
259
        self.vm1 = mfactory.VirtualMachineFactory(userid=USER1)
260
        pk = self.vm1.pk
261

    
262
        r = self.client.post(reverse('helpdesk-vm-shutdown', args=(pk,)))
263
        self.assertEqual(r.status_code, 403)
264

    
265
        r = self.client.post(reverse('helpdesk-vm-shutdown', args=(pk,)),
266
                             data={'token': '0001'})
267
        self.assertEqual(r.status_code, 403)
268

    
269
        backend.shutdown_instance = shutdown = mock.Mock()
270
        self.vm1.operstate = 'STARTED'
271
        self.vm1.save()
272
        r = self.client.post(reverse('helpdesk-vm-shutdown', args=(pk,)),
273
                             data={'token': '0001'}, user_token='0001')
274
        self.assertEqual(r.status_code, 302)
275
        self.assertTrue(shutdown.called)
276
        self.assertEqual(len(shutdown.mock_calls), 1)
277

    
278
        backend.startup_instance = startup = mock.Mock()
279
        self.vm1.operstate = 'STOPPED'
280
        self.vm1.save()
281
        r = self.client.post(reverse('helpdesk-vm-start', args=(pk,)),
282
                             data={'token': '0001'}, user_token='0001')
283
        self.assertEqual(r.status_code, 302)
284
        self.assertTrue(startup.called)
285
        self.assertEqual(len(startup.mock_calls), 1)