mirror of
https://github.com/saltstack/salt.git
synced 2025-04-17 10:10:20 +00:00
Added unit tests for new _validate_name function and adjusted regex
This commit is contained in:
parent
388815112c
commit
9a4228d906
2 changed files with 109 additions and 4 deletions
|
@ -1033,7 +1033,7 @@ def _validate_name(name):
|
|||
'''
|
||||
ret = True
|
||||
name_length = len(name)
|
||||
regex = re.compile(r'^\w+$')
|
||||
regex = re.compile(r'^[a-zA-Z0-9][A-Za-z0-9_-]*[a-zA-Z0-9]$')
|
||||
|
||||
if name_length < 3 or name_length > 48:
|
||||
ret = False
|
||||
|
@ -1041,9 +1041,6 @@ def _validate_name(name):
|
|||
if not re.match(regex, name):
|
||||
ret = False
|
||||
|
||||
if name.startswith(('-', '_',)) or name.endswith(('-', '_',)):
|
||||
ret = False
|
||||
|
||||
if ret is False:
|
||||
log.warning(
|
||||
'A Linode label may only contain ASCII letters or numbers, dashes, and '
|
||||
|
|
108
tests/unit/cloud/clouds/linode_test.py
Normal file
108
tests/unit/cloud/clouds/linode_test.py
Normal file
|
@ -0,0 +1,108 @@
|
|||
# -*- 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.cloud.clouds import linode
|
||||
|
||||
|
||||
@skipIf(NO_MOCK, NO_MOCK_REASON)
|
||||
class LinodeTestCase(TestCase):
|
||||
'''
|
||||
Unit TestCase for the salt.cloud.clouds.linode module.
|
||||
'''
|
||||
|
||||
# _validate_name tests
|
||||
|
||||
def test_validate_name_first_character_invalid(self):
|
||||
'''
|
||||
Tests when name starts with an invalid character.
|
||||
'''
|
||||
# Test when name begins with a hyphen
|
||||
self.assertFalse(linode._validate_name('-foo'))
|
||||
|
||||
# Test when name begins with an underscore
|
||||
self.assertFalse(linode._validate_name('_foo'))
|
||||
|
||||
def test_validate_name_last_character_invalid(self):
|
||||
'''
|
||||
Tests when name ends with an invalid character.
|
||||
'''
|
||||
# Test when name ends with a hyphen
|
||||
self.assertFalse(linode._validate_name('foo-'))
|
||||
|
||||
# Test when name ends with an underscore
|
||||
self.assertFalse(linode._validate_name('foo_'))
|
||||
|
||||
def test_validate_name_too_short(self):
|
||||
'''
|
||||
Tests when name has less than three letters.
|
||||
'''
|
||||
# Test when name is an empty string
|
||||
self.assertFalse(linode._validate_name(''))
|
||||
|
||||
# Test when name is two letters long
|
||||
self.assertFalse(linode._validate_name('ab'))
|
||||
|
||||
# Test when name is three letters long (valid)
|
||||
self.assertTrue(linode._validate_name('abc'))
|
||||
|
||||
def test_validate_name_too_long(self):
|
||||
'''
|
||||
Tests when name has more than 48 letters.
|
||||
'''
|
||||
long_name = '1111-2222-3333-4444-5555-6666-7777-8888-9999-111'
|
||||
# Test when name is 48 letters long (valid)
|
||||
self.assertEqual(len(long_name), 48)
|
||||
self.assertTrue(linode._validate_name(long_name))
|
||||
|
||||
# Test when name is more than 48 letters long
|
||||
long_name += '1'
|
||||
self.assertEqual(len(long_name), 49)
|
||||
self.assertFalse(linode._validate_name(long_name))
|
||||
|
||||
def test_validate_name_invalid_characters(self):
|
||||
'''
|
||||
Tests when name contains invalid characters.
|
||||
'''
|
||||
# Test when name contains an invalid character
|
||||
self.assertFalse(linode._validate_name('foo;bar'))
|
||||
|
||||
# Test when name contains non-ascii letters
|
||||
self.assertFalse(linode._validate_name('fooàààààbar'))
|
||||
|
||||
# Test when name contains spaces
|
||||
self.assertFalse(linode._validate_name('foo bar'))
|
||||
|
||||
def test_validate_name_valid_characters(self):
|
||||
'''
|
||||
Tests when name contains valid characters.
|
||||
'''
|
||||
# Test when name contains letters and numbers
|
||||
self.assertTrue(linode._validate_name('foo123bar'))
|
||||
|
||||
# Test when name contains hyphens
|
||||
self.assertTrue(linode._validate_name('foo-bar'))
|
||||
|
||||
# Test when name contains underscores
|
||||
self.assertTrue(linode._validate_name('foo_bar'))
|
||||
|
||||
# Test when name start and end with numbers
|
||||
self.assertTrue(linode._validate_name('1foo'))
|
||||
self.assertTrue(linode._validate_name('foo0'))
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
from integration import run_tests
|
||||
run_tests(LinodeTestCase, needs_daemon=False)
|
Loading…
Add table
Reference in a new issue