aboutsummaryrefslogtreecommitdiffstats
path: root/ice_validator/tests/test_base_template_names.py
diff options
context:
space:
mode:
authorLovett, Trevor <trevor.lovett@att.com>2020-04-30 14:50:02 -0500
committerLovett, Trevor <trevor.lovett@att.com>2020-04-30 14:50:02 -0500
commit4b53cbbf12894610774b5e024cecb0d4e395aad3 (patch)
tree7522eaf8d208c1fcdd4dbbaec8ea993bd988139d /ice_validator/tests/test_base_template_names.py
parentba669ca219cf8bb9dc64deff9f22941be2fb4388 (diff)
Enforce filename rules
Disallow characters other than alphanumerics and underscores in Heat template file names Change-Id: I097ad1830fdc10fb431daef6ec713d825ee8b42a Issue-ID: VVP-415 Signed-off-by: Lovett, Trevor <trevor.lovett@att.com>
Diffstat (limited to 'ice_validator/tests/test_base_template_names.py')
-rw-r--r--ice_validator/tests/test_base_template_names.py37
1 files changed, 26 insertions, 11 deletions
diff --git a/ice_validator/tests/test_base_template_names.py b/ice_validator/tests/test_base_template_names.py
index 1159fb6..861843f 100644
--- a/ice_validator/tests/test_base_template_names.py
+++ b/ice_validator/tests/test_base_template_names.py
@@ -2,7 +2,7 @@
# ============LICENSE_START====================================================
# org.onap.vvp/validation-scripts
# ===================================================================
-# Copyright © 2019 AT&T Intellectual Property. All rights reserved.
+# Copyright © 2020 AT&T Intellectual Property. All rights reserved.
# ===================================================================
#
# Unless otherwise specified, all software contained herein is licensed
@@ -18,8 +18,6 @@
# See the License for the specific language governing permissions and
# limitations under the License.
#
-#
-#
# Unless otherwise specified, all documentation contained herein is licensed
# under the Creative Commons License, Attribution 4.0 Intl. (the "License");
# you may not use this documentation except in compliance with the License.
@@ -34,12 +32,11 @@
# limitations under the License.
#
# ============LICENSE_END============================================
-#
-#
from os import listdir
from os import path
import re
+from pathlib import Path
import pytest
@@ -50,18 +47,36 @@ from .helpers import validates
RE_BASE = re.compile(r"(^base$)|(^base_)|(_base_)|(_base$)")
-@validates("R-37028", "R-87485", "R-81339", "R-87247", "R-76057")
-def test_base_template_names(template_dir):
- """
- Check all base templates have a filename that includes "_base_".
- """
- filenames = [
+def list_filenames(template_dir):
+ return [
f
for f in listdir(template_dir)
if path.isfile(path.join(template_dir, f))
and path.splitext(f)[-1] in [".yaml", ".yml"]
]
+
+@validates("R-81339", "R-87247", "R-76057")
+def test_template_names_valid_characters(template_dir):
+ filenames = list_filenames(template_dir)
+ errors = []
+ for f in filenames:
+ stem = Path(f).stem
+ if not stem.replace("_", "").isalnum():
+ errors.append(f)
+ assert not errors, (
+ "The following Heat template names include characters other than "
+ "alphanumerics and underscores: {}"
+ ).format(", ".join(errors))
+
+
+@validates("R-37028", "R-87485", "R-81339", "R-87247", "R-76057")
+def test_base_template_names(template_dir):
+ """
+ Check all base templates have a filename that includes "_base_".
+ """
+ filenames = list_filenames(template_dir)
+
if not filenames and listdir(template_dir):
pytest.skip("Nested directory detected. Let that test fail instead.")