diff options
author | Varma, Vikas <vv8305@att.com> | 2018-09-14 17:56:41 -0400 |
---|---|---|
committer | Varma, Vikas <vv8305@att.com> | 2018-09-14 17:57:24 -0400 |
commit | 0255242087453befa24f1b7cde905c8869267a20 (patch) | |
tree | ea21d7381d628efc0137821aa4cd7b478c5d05a9 /test/test_aaf_authentication.py | |
parent | 3ab841597bd7fbfa4de41791c9d7e6335c8afeb9 (diff) |
Add unit test cases for aaf auth api
Change-Id: I611f3fc8dcfe9570d3202bb1473f163168d22d7c
Signed-off-by: Varma, Vikas <vv8305@att.com>
Issue-ID: OPTFRA-339
Diffstat (limited to 'test/test_aaf_authentication.py')
-rw-r--r-- | test/test_aaf_authentication.py | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/test/test_aaf_authentication.py b/test/test_aaf_authentication.py new file mode 100644 index 0000000..7f5207e --- /dev/null +++ b/test/test_aaf_authentication.py @@ -0,0 +1,104 @@ +import os +from flask import Flask +from mock import mock + +from osdf.adapters.aaf import aaf_authentication as auth +from osdf.utils.interfaces import RestClient + +BASE_DIR = os.path.dirname(__file__) + + +class TestAafAuthentication(): + + def test_authenticate(self): + app = Flask(__name__) + auth.clear_cache() + + def mock_aaf_response(*args, **kwargs): + return {"perm": [{"instance": "menu_ecd", "action": "*", "type": "org.onap.oof.controller.dev.menu"}, + {"instance": "*", "action": "*", "type": "org.onap.osdf.access"}, + {"instance": "aaf", "action": "request", "type": "org.onap.osdf.certman"}, + {"instance": "*", "action": "*", "type": "org.onap.osdf.dev.access"}, + {"instance": ":*:*", "action": "*", "type": "org.onap.osdf.dev.k8"}, + {"instance": ":*:*", "action": "*", "type": "org.onap.osdf.ist.k8"}]} + + with app.test_request_context(path='/api/oof/v1/placement'): + with mock.patch.object(RestClient, 'request', side_effect=mock_aaf_response): + assert auth.authenticate('user', 'password') + + def test_auth_cache(self): + app = Flask(__name__) + auth.clear_cache() + + def mock_aaf_response(*args, **kwargs): + return {"perm": [{"instance": "menu_ecd", "action": "*", "type": "org.onap.oof.controller.dev.menu"}, + {"instance": "*", "action": "*", "type": "org.onap.osdf.access"}, + {"instance": "aaf", "action": "request", "type": "org.onap.osdf.certman"}, + {"instance": "*", "action": "*", "type": "org.onap.osdf.dev.access"}, + {"instance": ":*:*", "action": "*", "type": "org.onap.osdf.dev.k8"}, + {"instance": ":*:*", "action": "*", "type": "org.onap.osdf.ist.k8"}]} + + with app.test_request_context(path='/api/oof/v1/placement'): + with mock.patch.object(RestClient, 'request', side_effect=mock_aaf_response): + assert auth.authenticate('user', 'password') + assert auth.authenticate('user', 'password') + + def test_authenticate_fail(self): + app = Flask(__name__) + auth.clear_cache() + + def mock_aaf_response(*args, **kwargs): + return {"perm": [{"instance": "menu_ecd", "action": "*", "type": "org.onap.oof.controller.dev.menu"}]} + + with app.test_request_context(path='/api/oof/v1/placement'): + with mock.patch.object(RestClient, 'request', side_effect=mock_aaf_response): + assert not auth.authenticate('user1', 'password1') + + def test_authenticate_uri_mismatch(self): + app = Flask(__name__) + auth.clear_cache() + + def mock_aaf_response(*args, **kwargs): + return {"perm": [{"instance": "menu_ecd", "action": "*", "type": "org.onap.oof.controller.dev.menu"}, + {"instance": "*", "action": "*", "type": "org.onap.osdf.access"}, + {"instance": "aaf", "action": "request", "type": "org.onap.osdf.certman"}, + {"instance": "*", "action": "*", "type": "org.onap.osdf.dev.access"}, + {"instance": ":*:*", "action": "*", "type": "org.onap.osdf.dev.k8"}, + {"instance": ":*:*", "action": "*", "type": "org.onap.osdf.ist.k8"}]} + + with app.test_request_context(path='/sniro/wrong/uri'): + with mock.patch.object(RestClient, 'request', side_effect=mock_aaf_response): + assert not auth.authenticate('user', 'password') + + def test_authenticate_fail1(self): + app = Flask(__name__) + auth.clear_cache() + + def mock_aaf_response(*args, **kwargs): + return {} + + with app.test_request_context(path='/api/oof/v1/placement'): + with mock.patch.object(RestClient, 'request', side_effect=mock_aaf_response): + assert not auth.authenticate('user2', 'password2') + + def test_authenticate_fail3(self): + app = Flask(__name__) + auth.clear_cache() + + def mock_aaf_response2(*args, **kwargs): + return {} + + with app.test_request_context(path='/api/oof/v1/placement'): + with mock.patch.object(RestClient, 'request', side_effect=mock_aaf_response2): + assert not auth.authenticate('user3', 'password3') + + def test_authenticate_except(self): + app = Flask(__name__) + auth.clear_cache() + + def mock_aaf_response2(*args, **kwargs): + raise Exception('This is the exception you expect to handle') + + with app.test_request_context(path='/api/oof/v1/placement'): + with mock.patch.object(RestClient, 'request', side_effect=mock_aaf_response2): + assert not auth.authenticate('user3', 'password3') |