aboutsummaryrefslogtreecommitdiffstats
path: root/tests/packager/test_csar.py
diff options
context:
space:
mode:
authorLianhao Lu <lianhao.lu@intel.com>2018-08-29 13:55:41 +0800
committerLianhao Lu <lianhao.lu@intel.com>2018-08-29 13:55:41 +0800
commit7db9cd91cd0b25000fca4c3ffb5c59cc413ad3f6 (patch)
tree6a8c9a76aa82f17d7c76be2c1da470b4c8e23683 /tests/packager/test_csar.py
parent03257fcd7885f7a8c47e2f8f34204097201f5b89 (diff)
Added more logic about cmd param validation
Shouldn't allow the user to set digest or certificate if manifest is not set. Change-Id: Iccb9f038106d52039f75ce80af1cce3858d1fba5 Issue-ID: VNFSDK-311 Signed-off-by: Lianhao Lu <lianhao.lu@intel.com>
Diffstat (limited to 'tests/packager/test_csar.py')
-rw-r--r--tests/packager/test_csar.py37
1 files changed, 37 insertions, 0 deletions
diff --git a/tests/packager/test_csar.py b/tests/packager/test_csar.py
index e9e441c..04efca7 100644
--- a/tests/packager/test_csar.py
+++ b/tests/packager/test_csar.py
@@ -19,6 +19,8 @@ import os
import tempfile
import shutil
+import pytest
+
from vnfsdk_pkgtools.packager import csar
CSAR_RESOURCE_DIR = 'tests/resources/csar'
@@ -78,6 +80,30 @@ ARGS_NO_MANIFEST = {
'privkey': None,
}
+INVALID_ARGS_NO_MANIFEST = {
+ 'source': CSAR_RESOURCE_DIR,
+ 'entry': CSAR_ENTRY_FILE,
+ 'manifest': None,
+ 'history': None,
+ 'tests': None,
+ 'licenses': None,
+ 'digest': 'sha256',
+ 'certificate': None,
+ 'privkey': None,
+ }
+
+INVALID_ARGS_NO_PRIVKEY = {
+ 'source': CSAR_RESOURCE_DIR,
+ 'entry': CSAR_ENTRY_FILE,
+ 'manifest': 'test_entry.mf',
+ 'history': None,
+ 'tests': None,
+ 'licenses': None,
+ 'digest': None,
+ 'certificate': 'test.crt',
+ 'privkey': None,
+ }
+
def csar_write_test(args):
csar_target_dir = tempfile.mkdtemp()
@@ -116,9 +142,20 @@ def test_CSARWrite_manifest_digest():
os.makedirs(license_path)
csar_write_test(Args(**ARGS_MANIFEST_DIGEST))
+
def test_CSARWrite_manifest_digest_cert():
# Because git can not store emptry directory, we need to create manually here
license_path = ARGS_MANIFEST['source'] + '/' + ARGS_MANIFEST['licenses']
if not os.path.exists(license_path):
os.makedirs(license_path)
csar_write_test(Args(**ARGS_MANIFEST_DIGEST_CERT))
+
+
+def test_CSARWrite_invalid_arg():
+ with pytest.raises(ValueError) as excinfo:
+ csar_write_test(Args(**INVALID_ARGS_NO_MANIFEST))
+ excinfo.match(r"Must specify manifest file")
+
+ with pytest.raises(ValueError) as excinfo:
+ csar_write_test(Args(**INVALID_ARGS_NO_PRIVKEY))
+ excinfo.match(r"Need private key file")