Formalize constants for property names 17/27217/3
authorYujun Zhang <zhang.yujunz@zte.com.cn>
Thu, 19 Jan 2017 07:10:01 +0000 (15:10 +0800)
committerYujun Zhang <zhang.yujunz@zte.com.cn>
Mon, 23 Jan 2017 04:16:12 +0000 (12:16 +0800)
Change-Id: I68560b2299c2a815219bc0d0399124e0c269a2c0
Signed-off-by: Yujun Zhang <zhang.yujunz@zte.com.cn>
qtip/base/constant.py
qtip/loader/base.py
qtip/loader/plan.py
qtip/loader/qpi.py
qtip/runner/__init__.py
tests/unit/loader/metric_test.py
tests/unit/loader/plan_test.py
tests/unit/loader/qpi_test.py

index 76481b4..58cc0cc 100644 (file)
@@ -25,26 +25,49 @@ class PkgName(object):
     SPEC = 'spec'
 
 
-class PropName(object):
+class BaseProp(object):
     """property names"""
     # list
     NAME = 'name'
     CONTENT = 'content'
     ABSPATH = 'abspath'
+
     # content
-    name = 'name'
     DESCRIPTION = 'description'
+
+
+class SpecProp(BaseProp):
     # spec
     SECTIONS = 'sections'
     WEIGHT = 'weight'
     FORMULA = 'formula'
     METRICS = 'metrics'
     WORKLOADS = 'workloads'
+
+
+class PlanProp(BaseProp):
     # plan
-    CONFIG = 'config'
+    INFO = 'info'
+
     FACILITY = 'facility'
     ENGINEER = 'engineer'
+
+    CONFIG = 'config'
+
     DRIVER = 'driver'
     COLLECTOR = 'collector'
     REPORTER = 'reporter'
+
     QPIS = 'QPIs'
+
+
+class CollectorProp(BaseProp):
+    LOGS = 'logs'
+    FILENAME = 'filename'
+    PATTERNS = 'patterns'
+    MATCH = 'match'
+    CAPTURE = 'capture'
+
+
+class ReporterBaseProp(BaseProp):
+    TRANSFORMER = 'transformer'
index d3a7e1d..a0e5d03 100644 (file)
@@ -7,13 +7,14 @@
 # http://www.apache.org/licenses/LICENSE-2.0
 ##############################################################################
 
+from collections import defaultdict
 from itertools import chain
 from os import listdir
 from os import path
 import yaml
 
 from qtip.base.error import InvalidFormat, NotFound
-from qtip.base.constant import PropName
+from qtip.base.constant import BaseProp
 
 
 ROOT_DIR = path.join(path.dirname(__file__), path.pardir, path.pardir,
@@ -28,15 +29,15 @@ class BaseLoader(object):
     def __init__(self, name, paths=None):
         self._file = name
         self._abspath = self._find(name, paths=paths)
+        content = defaultdict(lambda: None)
 
         try:
-            content = yaml.safe_load(file(self._abspath))
+            content.update(yaml.safe_load(file(self._abspath)))
         except yaml.YAMLError:
             # TODO(yujunz) log yaml error
             raise InvalidFormat(self._abspath)
 
-        self.name = content[PropName.NAME] if PropName.NAME in content \
-            else path.splitext(name)[0]
+        self.name = content[BaseProp.NAME] or path.splitext(name)[0]
         self.content = content
 
     def _find(self, name, paths=None):
@@ -57,6 +58,6 @@ class BaseLoader(object):
         for name in names:
             item = cls(name, paths=paths)
             yield {
-                PropName.NAME: name,
-                PropName.ABSPATH: item._abspath,
-                PropName.CONTENT: item.content}
+                BaseProp.NAME: name,
+                BaseProp.ABSPATH: item._abspath,
+                BaseProp.CONTENT: item.content}
index cf517ea..c1ee00b 100644 (file)
@@ -8,7 +8,7 @@
 ##############################################################################
 
 
-from qtip.base.constant import PropName
+from qtip.base.constant import PlanProp
 from qtip.loader.base import BaseLoader
 from qtip.loader.qpi import QPISpec
 
@@ -24,4 +24,5 @@ class Plan(BaseLoader):
         super(Plan, self).__init__(name, paths)
 
         self.qpis = [QPISpec(qpi, paths=paths)
-                     for qpi in self.content[PropName.QPIS]]
+                     for qpi in self.content[PlanProp.QPIS]]
+        self.info = self.content[PlanProp.INFO]
index fe2323d..ef6e065 100644 (file)
@@ -10,7 +10,7 @@
 from base import BaseLoader
 from metric import MetricSpec
 
-from qtip.base.constant import PropName
+from qtip.base.constant import SpecProp
 from qtip.util.formula import Formula
 
 
@@ -24,15 +24,15 @@ class QPISpec(BaseLoader):
     def __init__(self, name, paths=None):
         super(QPISpec, self).__init__(name, paths=paths)
         content = self.content
-        self.formula = Formula(content[PropName.FORMULA])
+        self.formula = Formula(content[SpecProp.FORMULA])
         self.sections = [Section(record, paths=paths)
-                         for record in content[PropName.SECTIONS]]
+                         for record in content[SpecProp.SECTIONS]]
 
 
 class Section(object):
     def __init__(self, content, paths=None):
-        self.name = content[PropName.NAME]
-        self.weight = content[PropName.WEIGHT]
-        self.formula = Formula(content[PropName.FORMULA])
+        self.name = content[SpecProp.NAME]
+        self.weight = content[SpecProp.WEIGHT]
+        self.formula = Formula(content[SpecProp.FORMULA])
         self.metrics = [MetricSpec(record, paths=paths)
-                        for record in content[PropName.METRICS]]
+                        for record in content[SpecProp.METRICS]]
index eab8115..1db8498 100644 (file)
@@ -7,7 +7,7 @@
 # http://www.apache.org/licenses/LICENSE-2.0
 ##############################################################################
 
-from qtip.base.constant import PkgName, PropName
+from qtip.base.constant import PkgName, BaseProp
 from qtip.base.error import NotFound
 from qtip.collector.stdout import StdoutCollector
 from qtip.driver.random import RandomDriver
@@ -17,11 +17,11 @@ from qtip.reporter.console import ConsoleReporter
 class Runner(object):
     def __init__(self, spec, config=None):
         if config is None:
-            config = spec[PropName.CONFIG]
+            config = spec[BaseProp.CONFIG]
 
-        driver_name = config[PropName.DRIVER]
-        collector_name = config[PropName.COLLECTOR]
-        reporter_name = config[PropName.REPORTER]
+        driver_name = config[BaseProp.DRIVER]
+        collector_name = config[BaseProp.COLLECTOR]
+        reporter_name = config[BaseProp.REPORTER]
 
         # TODO(yujunz) dynamically load modules by name
 
index d2be038..91d0dd2 100644 (file)
@@ -9,7 +9,7 @@
 
 import pytest
 
-from qtip.base.constant import PropName
+from qtip.base.constant import BaseProp
 from qtip.loader.metric import MetricSpec
 
 
@@ -31,15 +31,15 @@ def list_all_test():
     metric_list = MetricSpec.list_all()
     assert len(list(metric_list)) is 6
     for desc in metric_list:
-        assert PropName.NAME in desc
-        assert PropName.DESCRIPTION in desc
-        assert PropName.ABSPATH in desc
-        assert PropName.ABSPATH is not None
+        assert BaseProp.NAME in desc
+        assert BaseProp.DESCRIPTION in desc
+        assert BaseProp.ABSPATH in desc
+        assert BaseProp.ABSPATH is not None
 
 
 def content_test(metric):
     content = metric.content
-    assert PropName.NAME in content
-    assert PropName.DESCRIPTION in content
-    assert PropName.WORKLOADS in content
-    assert isinstance(content[PropName.WORKLOADS], list)
+    assert BaseProp.NAME in content
+    assert BaseProp.DESCRIPTION in content
+    assert BaseProp.WORKLOADS in content
+    assert isinstance(content[BaseProp.WORKLOADS], list)
index 6aab5e8..b57bcfb 100644 (file)
@@ -9,7 +9,7 @@
 
 import pytest
 
-from qtip.base.constant import PropName
+from qtip.base.constant import PlanProp
 from qtip.loader.plan import Plan, QPISpec
 
 
@@ -29,15 +29,15 @@ def test_list_all(benchmarks_root):
     plan_list = Plan.list_all(paths=[benchmarks_root])
     assert len(list(plan_list)) is 1
     for desc in plan_list:
-        assert PropName.NAME in desc
-        assert PropName.CONTENT in desc
-        assert PropName.ABSPATH in desc
-        assert PropName.ABSPATH is not None
+        assert PlanProp.NAME in desc
+        assert PlanProp.CONTENT in desc
+        assert PlanProp.ABSPATH in desc
+        assert PlanProp.ABSPATH is not None
 
 
 def test_content(plan):
     content = plan.content
-    assert PropName.NAME in content
-    assert PropName.DESCRIPTION in content
-    assert PropName.CONFIG in content
-    assert PropName.QPIS in content
+    assert PlanProp.NAME in content
+    assert PlanProp.DESCRIPTION in content
+    assert PlanProp.CONFIG in content
+    assert PlanProp.QPIS in content
index 4b3fd4d..3328b43 100644 (file)
@@ -9,7 +9,7 @@
 
 import pytest
 
-from qtip.base.constant import FormulaName, PropName
+from qtip.base.constant import FormulaName, SpecProp
 from qtip.loader.qpi import QPISpec
 
 QPI_SPEC = 'compute.yaml'
@@ -33,20 +33,20 @@ def test_list_all(benchmarks_root):
     qpi_spec_list = QPISpec.list_all(paths=[benchmarks_root])
     assert len(list(qpi_spec_list)) is 2
     for item in qpi_spec_list:
-        assert PropName.NAME in item
-        assert PropName.CONTENT in item
-        assert PropName.ABSPATH in item
-        assert PropName.ABSPATH is not None
+        assert SpecProp.NAME in item
+        assert SpecProp.CONTENT in item
+        assert SpecProp.ABSPATH in item
+        assert SpecProp.ABSPATH is not None
 
 
 def test_content(qpi_spec):
     content = qpi_spec.content
-    assert PropName.DESCRIPTION in content
-    assert PropName.FORMULA in content
-    assert PropName.SECTIONS in content
+    assert SpecProp.DESCRIPTION in content
+    assert SpecProp.FORMULA in content
+    assert SpecProp.SECTIONS in content
 
-    assert content[PropName.FORMULA] in FormulaName.__dict__.values()
-    sections = content[PropName.SECTIONS]
+    assert content[SpecProp.FORMULA] in FormulaName.__dict__.values()
+    sections = content[SpecProp.SECTIONS]
     assert isinstance(sections, list)
     for section in sections:
-        assert PropName.NAME in section
+        assert SpecProp.NAME in section