26fff6f5c3
Add header option to request method in NetAppESeriesModule Add multipart formdata builder function Fix issue with url port change
106 lines
5 KiB
Python
106 lines
5 KiB
Python
# (c) 2018, NetApp Inc.
|
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
|
|
|
|
__metaclass__ = type
|
|
|
|
try:
|
|
from unittest.mock import patch, mock_open
|
|
except ImportError:
|
|
from mock import patch, mock_open
|
|
|
|
from ansible.module_utils.six.moves.urllib.error import URLError
|
|
from ansible.module_utils.netapp import NetAppESeriesModule, create_multipart_formdata
|
|
from units.modules.utils import AnsibleExitJson, AnsibleFailJson, ModuleTestCase, set_module_args
|
|
|
|
|
|
class StubNetAppESeriesModule(NetAppESeriesModule):
|
|
def __init__(self):
|
|
super(StubNetAppESeriesModule, self).__init__(ansible_options={})
|
|
|
|
|
|
class NetappTest(ModuleTestCase):
|
|
REQUIRED_PARAMS = {"api_username": "rw",
|
|
"api_password": "password",
|
|
"api_url": "http://localhost",
|
|
"ssid": "1"}
|
|
REQ_FUNC = "ansible.module_utils.netapp.request"
|
|
|
|
def _set_args(self, args=None):
|
|
module_args = self.REQUIRED_PARAMS.copy()
|
|
if args is not None:
|
|
module_args.update(args)
|
|
set_module_args(module_args)
|
|
|
|
def test_is_embedded_embedded_pass(self):
|
|
"""Verify is_embedded successfully returns True when an embedded web service's rest api is inquired."""
|
|
self._set_args()
|
|
with patch(self.REQ_FUNC, side_effect=[(200, {"version": "03.10.9000.0009"}),
|
|
(200, {"runningAsProxy": False})]):
|
|
base = StubNetAppESeriesModule()
|
|
self.assertTrue(base.is_embedded())
|
|
with patch(self.REQ_FUNC, side_effect=[(200, {"version": "03.10.9000.0009"}),
|
|
(200, {"runningAsProxy": True})]):
|
|
base = StubNetAppESeriesModule()
|
|
self.assertFalse(base.is_embedded())
|
|
|
|
def test_is_embedded_fail(self):
|
|
"""Verify exception is thrown when a web service's rest api fails to return about information."""
|
|
self._set_args()
|
|
with patch(self.REQ_FUNC, side_effect=[(200, {"version": "03.10.9000.0009"}), Exception()]):
|
|
with self.assertRaisesRegexp(AnsibleFailJson, r"Failed to retrieve the webservices about information!"):
|
|
base = StubNetAppESeriesModule()
|
|
base.is_embedded()
|
|
with patch(self.REQ_FUNC, side_effect=[(200, {"version": "03.10.9000.0009"}), URLError(""), Exception()]):
|
|
with self.assertRaisesRegexp(AnsibleFailJson, r"Failed to retrieve the webservices about information!"):
|
|
base = StubNetAppESeriesModule()
|
|
base.is_embedded()
|
|
|
|
def test_check_web_services_version_fail(self):
|
|
"""Verify that an unacceptable rest api version fails."""
|
|
minimum_required = "02.10.9000.0010"
|
|
test_set = ["02.10.9000.0009", "02.09.9000.0010", "01.10.9000.0010"]
|
|
|
|
self._set_args()
|
|
base = StubNetAppESeriesModule()
|
|
base.web_services_version = minimum_required
|
|
base.is_embedded = lambda: True
|
|
for current_version in test_set:
|
|
with patch(self.REQ_FUNC, return_value=(200, {"version": current_version})):
|
|
with self.assertRaisesRegexp(AnsibleFailJson, r"version does not meet minimum version required."):
|
|
base._check_web_services_version()
|
|
|
|
def test_check_web_services_version_pass(self):
|
|
"""Verify that an unacceptable rest api version fails."""
|
|
minimum_required = "02.10.9000.0010"
|
|
test_set = ["02.10.9000.0009", "02.09.9000.0010", "01.10.9000.0010"]
|
|
|
|
self._set_args()
|
|
base = StubNetAppESeriesModule()
|
|
base.web_services_version = minimum_required
|
|
base.is_embedded = lambda: True
|
|
for current_version in test_set:
|
|
with patch(self.REQ_FUNC, return_value=(200, {"version": current_version})):
|
|
with self.assertRaisesRegexp(AnsibleFailJson, r"version does not meet minimum version required."):
|
|
base._check_web_services_version()
|
|
|
|
def test_check_check_web_services_version_fail(self):
|
|
"""Verify exception is thrown when api url is invalid."""
|
|
invalid_url_forms = ["localhost:8080/devmgr/v2",
|
|
"http:///devmgr/v2"]
|
|
|
|
invalid_url_protocols = ["ssh://localhost:8080/devmgr/v2"]
|
|
|
|
for url in invalid_url_forms:
|
|
self._set_args({"api_url": url})
|
|
with patch(self.REQ_FUNC, return_value=(200, {"runningAsProxy": True})):
|
|
with self.assertRaisesRegexp(AnsibleFailJson, r"Failed to provide valid API URL."):
|
|
base = StubNetAppESeriesModule()
|
|
base._check_web_services_version()
|
|
|
|
for url in invalid_url_protocols:
|
|
self._set_args({"api_url": url})
|
|
with patch(self.REQ_FUNC, return_value=(200, {"runningAsProxy": True})):
|
|
with self.assertRaisesRegexp(AnsibleFailJson, r"Protocol must be http or https."):
|
|
base = StubNetAppESeriesModule()
|
|
base._check_web_services_version()
|