diff options
author | 2018-08-29 13:55:41 +0800 | |
---|---|---|
committer | 2018-08-29 13:55:41 +0800 | |
commit | 7db9cd91cd0b25000fca4c3ffb5c59cc413ad3f6 (patch) | |
tree | 6a8c9a76aa82f17d7c76be2c1da470b4c8e23683 /tests/packager/test_csar.py | |
parent | 03257fcd7885f7a8c47e2f8f34204097201f5b89 (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.py | 37 |
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") |