Add unit tests for new recursive function

This commit is contained in:
rallytime 2015-09-29 21:25:47 -06:00
parent d9a2dc6bc5
commit 78c85fbb31
2 changed files with 106 additions and 6 deletions

View file

@ -810,26 +810,26 @@ def sanitize_url(url, hide_fields):
comps_list = pair.split('&')
if url_tmp:
url_tmp = url_tmp.split('&')
url_tmp = _sanitize_components(url_tmp, field)
url_tmp = _sanitize_url_components(url_tmp, field)
else:
url_tmp = _sanitize_components(comps_list, field)
url_tmp = _sanitize_url_components(comps_list, field)
log_url += url_tmp
return log_url.rstrip('&')
else:
return str(url)
def _sanitize_components(comp_list, field):
def _sanitize_url_components(comp_list, field):
'''
Use a recursive method to sanitize each component of the url.
Recursive function to sanitize each component of the url.
'''
if len(comp_list) == 0:
return ''
elif comp_list[0].startswith('{0}='.format(field)):
ret = '{0}=XXXXXXXXXX&'.format(field)
comp_list.remove(comp_list[0])
return ret + _sanitize_components(comp_list, field)
return ret + _sanitize_url_components(comp_list, field)
else:
ret = '{0}&'.format(comp_list[0])
comp_list.remove(comp_list[0])
return ret + _sanitize_components(comp_list, field)
return ret + _sanitize_url_components(comp_list, field)

View file

@ -0,0 +1,100 @@
# -*- coding: utf-8 -*-
'''
:codeauthor: :email:`Nicole Thomas <nicole@saltstack.com>`
'''
# Import Salt Libs
from __future__ import absolute_import
# Import Salt Testing Libs
from salttesting import TestCase, skipIf
from salttesting.mock import NO_MOCK, NO_MOCK_REASON
from salttesting.helpers import ensure_in_syspath
ensure_in_syspath('../../')
# Import Salt Libs
from salt.utils import http
@skipIf(NO_MOCK, NO_MOCK_REASON)
class HTTPTestCase(TestCase):
'''
Unit TestCase for the salt.utils.http module.
'''
# sanitize_url tests
def test_sanitize_url_hide_fields_none(self):
'''
Tests sanitizing a url when the hide_fields kwarg is None.
'''
mock_url = 'https://api.testing.com/?&foo=bar&test=testing'
ret = http.sanitize_url(mock_url, hide_fields=None)
self.assertEqual(ret, mock_url)
def test_sanitize_url_no_elements(self):
'''
Tests sanitizing a url when no elements should be sanitized.
'''
mock_url = 'https://api.testing.com/?&foo=bar&test=testing'
ret = http.sanitize_url(mock_url, [''])
self.assertEqual(ret, mock_url)
def test_sanitize_url_single_element(self):
'''
Tests sanitizing a url with only a single element to be sanitized.
'''
mock_url = 'https://api.testing.com/?&keep_it_secret=abcdefghijklmn' \
'&api_action=module.function'
mock_ret = 'https://api.testing.com/?&keep_it_secret=XXXXXXXXXX&' \
'api_action=module.function'
ret = http.sanitize_url(mock_url, ['keep_it_secret'])
self.assertEqual(ret, mock_ret)
def test_sanitize_url_multiple_elements(self):
'''
Tests sanitizing a url with multiple elements to be sanitized.
'''
mock_url = 'https://api.testing.com/?rootPass=badpassword%21' \
'&skipChecks=True&api_key=abcdefghijklmn' \
'&NodeID=12345&api_action=module.function'
mock_ret = 'https://api.testing.com/?rootPass=XXXXXXXXXX' \
'&skipChecks=True&api_key=XXXXXXXXXX' \
'&NodeID=12345&api_action=module.function'
ret = http.sanitize_url(mock_url, ['api_key', 'rootPass'])
self.assertEqual(ret, mock_ret)
# _sanitize_components tests
def test_sanitize_components_no_elements(self):
'''
Tests when zero elements need to be sanitized.
'''
mock_component_list = ['foo=bar', 'bar=baz', 'hello=world']
mock_ret = 'foo=bar&bar=baz&hello=world&'
ret = http._sanitize_url_components(mock_component_list, 'api_key')
self.assertEqual(ret, mock_ret)
def test_sanitize_components_one_element(self):
'''
Tests a single component to be sanitized.
'''
mock_component_list = ['foo=bar', 'api_key=abcdefghijklmnop']
mock_ret = 'foo=bar&api_key=XXXXXXXXXX&'
ret = http._sanitize_url_components(mock_component_list, 'api_key')
self.assertEqual(ret, mock_ret)
def test_sanitize_components_multiple_elements(self):
'''
Tests two componenets to be sanitized.
'''
mock_component_list = ['foo=bar', 'foo=baz', 'api_key=testing']
mock_ret = 'foo=XXXXXXXXXX&foo=XXXXXXXXXX&api_key=testing&'
ret = http._sanitize_url_components(mock_component_list, 'foo')
self.assertEqual(ret, mock_ret)
if __name__ == '__main__':
from integration import run_tests
run_tests(HTTPTestCase, needs_daemon=False)