Decouple aria parser 13/9813/1
authorLianhao Lu <lianhao.lu@intel.com>
Fri, 1 Sep 2017 02:36:01 +0000 (10:36 +0800)
committerLianhao Lu <lianhao.lu@intel.com>
Fri, 1 Sep 2017 02:39:11 +0000 (10:39 +0800)
Use stevedore to make the aria parser as a plugin of the vnfsdk package
tool. Currently, the aria parser is still the default parser but 3rd
party developer can add other plugins as a parser to validate the csar
packages.

Change-Id: I4a1a1c5e65103fb93fa8aebf3d683781f4888ea4
Signed-off-by: Lianhao Lu <lianhao.lu@intel.com>
Issue-Id: VNFSDK-60

cli/__main__.py
requirements.txt
setup.py
validator/__init__.py [new file with mode: 0644]
validator/aria_validator.py [new file with mode: 0644]

index 2fe4d68..2ae0078 100644 (file)
@@ -22,15 +22,8 @@ from aria import install_aria_extensions
 import os\r
 import shutil\r
 import tempfile\r
-from aria.parser.loading import LiteralLocation\r
-from aria.parser.consumption import (\r
-    ConsumptionContext,\r
-    ConsumerChain,\r
-    Read,\r
-    Validate,\r
-    ServiceTemplate,\r
-    ServiceInstance\r
-)\r
+\r
+import validator\r
 \r
 def csar_create_func(namespace):\r
     csar.write(namespace.source,\r
@@ -48,16 +41,9 @@ def csar_validate_func(namespace):
         reader = csar.read(namespace.source,\r
                            workdir,\r
                            logging)\r
-        context = ConsumptionContext()\r
-        context.loading.prefixes += [os.path.join(reader.destination, 'definitions')]\r
-        context.presentation.location = LiteralLocation(reader.entry_definitions_yaml)\r
-        print reader.entry_definitions_yaml\r
-        chain = ConsumerChain(context, (Read, Validate, ServiceTemplate, ServiceInstance))\r
-        chain.consume()\r
-        if context.validation.dump_issues():\r
-            raise RuntimeError('Validation failed')\r
-        dumper = chain.consumers[-1]\r
-        dumper.dump()\r
+\r
+        driver = validator.get_validator(namespace.parser)\r
+        driver.validate(reader)\r
     finally:\r
         shutil.rmtree(workdir, ignore_errors=True)\r
 \r
@@ -104,6 +90,10 @@ def parse_args(args_list):
     csar_validate.add_argument(\r
         'source',\r
         help='CSAR file location')\r
+    csar_validate.add_argument(\r
+        '-p', '--parser',\r
+        default='aria',\r
+        help='use which csar parser to validate')\r
 \r
     return parser.parse_args(args_list)\r
 \r
index 245c3b4..0153edc 100644 (file)
@@ -1,3 +1,4 @@
 ruamel.yaml<0.12.0,>=0.11.12
 requests<2.14.0,>=2.3.0
 apache-ariatosca==0.1.1
+stevedore >= 1.9.0
index ab56412..61c8ec1 100644 (file)
--- a/setup.py
+++ b/setup.py
@@ -73,17 +73,22 @@ setup(
 \r
     packages=[\r
         'packager',\r
-        'cli'\r
+        'cli',\r
+        'validator'\r
     ],\r
 \r
     package_dir={\r
         'packager': 'packager',\r
         'cli': 'cli',\r
+        'validator': 'validator'\r
     },\r
 \r
     entry_points={\r
         'console_scripts': [\r
-            'vnfsdk = cli.__main__:main']\r
+            'vnfsdk = cli.__main__:main'],\r
+        'vnfsdk.validator': [\r
+            'aria = validator.aria_validator:AriaValidator'\r
+        ]\r
     },\r
 \r
     include_package_data=True,\r
diff --git a/validator/__init__.py b/validator/__init__.py
new file mode 100644 (file)
index 0000000..d33dcdf
--- /dev/null
@@ -0,0 +1,49 @@
+# Copyright (c) 2017 Intel Corp. All rights reserved.
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+#      http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+#
+
+import abc
+
+import six
+from stevedore import driver
+
+
+VALIDATOR_NS = "vnfsdk.validator"
+
+def get_validator(params):
+    """Get validate driver and load it.
+
+    :param params: parameters to decide which validator to load
+    """
+
+    loaded_driver = driver.DriverManager(VALIDATOR_NS,
+                                         params,
+                                         invoke_on_load=True)
+    return loaded_driver.driver
+
+
+@six.add_metaclass(abc.ABCMeta)
+class ValidatorBase(object):
+    """Base class for validators."""
+
+    def __init__(self):
+        pass
+
+
+    @abc.abstractmethod
+    def validate(self, reader):
+        """Validate the csar package.
+
+        :param reader: instance of package.csar._CSARReader
+        """
diff --git a/validator/aria_validator.py b/validator/aria_validator.py
new file mode 100644 (file)
index 0000000..6149790
--- /dev/null
@@ -0,0 +1,43 @@
+# Copyright (c) 2017 Intel Corp. All rights reserved.
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+#      http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+#
+
+import os
+
+from aria.parser.loading import LiteralLocation
+from aria.parser.consumption import (
+    ConsumptionContext,
+    ConsumerChain,
+    Read,
+    Validate,
+    ServiceTemplate,
+    ServiceInstance
+)
+
+import validator
+
+
+class AriaValidator(validator.ValidatorBase):
+    def validate(self, reader):
+        context = ConsumptionContext()
+        context.loading.prefixes += [os.path.join(reader.destination, 'definitions')]
+        context.presentation.location = LiteralLocation(reader.entry_definitions_yaml)
+        print reader.entry_definitions_yaml
+        chain = ConsumerChain(context, (Read, Validate, ServiceTemplate, ServiceInstance))
+        chain.consume()
+        if context.validation.dump_issues():
+            raise RuntimeError('Validation failed')
+        dumper = chain.consumers[-1]
+        dumper.dump()
+