1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
###############################################################################
# Copyright (c) 2017 Koren Lev (Cisco Systems), Yaron Yogev (Cisco Systems) #
# and others #
# #
# All rights reserved. This program and the accompanying materials #
# are made available under the terms of the Apache License, Version 2.0 #
# which accompanies this distribution, and is available at #
# http://www.apache.org/licenses/LICENSE-2.0 #
###############################################################################
import copy
from api.app import App
from api.middleware.authentication import AuthenticationMiddleware
from api.responders.responder_base import ResponderBase
from api.backends.ldap_access import LDAPAccess
from falcon.testing import TestCase
from test.api.responders_test.test_data import base
from unittest.mock import MagicMock
from utils.mongo_access import MongoAccess
def mock_auth_method(*args):
return None
class TestBase(TestCase):
def setUp(self, authenticate=False):
super().setUp()
# mock
self.authenticate = authenticate
if not authenticate:
self.original_auth_method = AuthenticationMiddleware.process_request
AuthenticationMiddleware.process_request = mock_auth_method
ResponderBase.get_constants_by_name = MagicMock(side_effect=
lambda name: base.CONSTANTS_BY_NAMES[name])
# mock mongo access
MongoAccess.mongo_connect = MagicMock()
MongoAccess.db = MagicMock()
MongoAccess.client = MagicMock()
# mock ldap access
LDAPAccess.get_ldap_params = MagicMock()
LDAPAccess.connect_ldap_server = MagicMock()
log_level = 'debug'
self.app = App(log_level=log_level).get_app()
def validate_get_request(self, url, params={}, headers=None, mocks={},
side_effects={},
expected_code=base.SUCCESSFUL_CODE,
expected_response=None):
self.validate_request("GET", url, params, headers, "",
mocks, side_effects,
expected_code,
expected_response)
def validate_request(self, action, url, params, headers, body,
mocks, side_effects, expected_code,
expected_response):
for mock_method, mock_data in mocks.items():
mock_method.return_value = mock_data
for mock_method, side_effect in side_effects.items():
mock_method.side_effect = side_effect
result = self.simulate_request(action, url, params=params, headers=headers, body=body)
self.assertEqual(result.status, expected_code)
if expected_response:
self.assertEqual(result.json, expected_response)
def validate_post_request(self, url, headers={}, body="", mocks={},
side_effects={},
expected_code=base.CREATED_CODE, expected_response=None):
self.validate_request("POST", url, {}, headers, body, mocks, side_effects,
expected_code, expected_response)
def validate_delete_request(self, url, params={}, headers={}, mocks={},
side_effects={},
expected_code=base.SUCCESSFUL_CODE, expected_response=None):
self.validate_request("DELETE", url, params, headers, "",
mocks, side_effects,
expected_code,
expected_response)
def get_updated_data(self, original_data, deleted_keys=None, updates=None):
copy_data = copy.deepcopy(original_data)
if deleted_keys is None:
deleted_keys = []
if updates is None:
updates = {}
for key in deleted_keys:
del copy_data[key]
for key, value in updates.items():
copy_data[key] = value
return copy_data
def tearDown(self):
# if the authentication method has been mocked, it needs to be reset after test
if not self.authenticate:
AuthenticationMiddleware.process_request = self.original_auth_method
|