diff options
author | Yujun Zhang <zhang.yujunz@zte.com.cn> | 2016-12-30 14:08:15 +0800 |
---|---|---|
committer | Yujun Zhang <zhang.yujunz@zte.com.cn> | 2017-01-03 18:16:12 +0800 |
commit | d8c05b528b5a75377848d130286bc997da06a792 (patch) | |
tree | d88f44e3a0d87ffdf64ba20ecf0417e01f63427f /tests | |
parent | decad5f7fdb212c4f78fc31f00e591eaba104450 (diff) |
Implement plan, qpi and metric constructors
- separate runner from `plan` and move `plan` to `loader`
- rename `algorithm` to `formula`
- use `numpy` for formulas
- update sample qpi and metrics
Change-Id: I3131ca79907376f2de31d6cb920bd7d0230664a6
Signed-off-by: Yujun Zhang <zhang.yujunz@zte.com.cn>
Diffstat (limited to 'tests')
-rw-r--r-- | tests/conftest.py | 3 | ||||
-rw-r--r-- | tests/data/benchmarks/QPI/compute.yaml | 37 | ||||
-rw-r--r-- | tests/data/benchmarks/QPI/fake-qpi.yaml | 6 | ||||
-rw-r--r-- | tests/data/benchmarks/metric/dhrystone.yaml | 6 | ||||
-rw-r--r-- | tests/data/benchmarks/metric/whetstone.yaml | 9 | ||||
-rw-r--r-- | tests/unit/loader/plan_test.py (renamed from tests/unit/runner/plan_test.py) | 7 | ||||
-rw-r--r-- | tests/unit/loader/qpi_test.py | 6 |
7 files changed, 36 insertions, 38 deletions
diff --git a/tests/conftest.py b/tests/conftest.py index f1ec91fb..7acb75e6 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -8,9 +8,10 @@ ############################################################################## from os import path + import pytest -from qtip.runner.plan import Plan +from qtip.loader.plan import Plan @pytest.fixture(scope='session') diff --git a/tests/data/benchmarks/QPI/compute.yaml b/tests/data/benchmarks/QPI/compute.yaml index 5ad8a4b6..e28efaf9 100644 --- a/tests/data/benchmarks/QPI/compute.yaml +++ b/tests/data/benchmarks/QPI/compute.yaml @@ -1,44 +1,29 @@ title: compute description: sample performance index of computing -algorithm: weighted arithmetic mean +formula: weighted arithmetic mean sections: - name: Integer weight: 0.3 - algorithm: geometric mean + formula: geometric mean metrics: - - spec: dhrystone.yaml - workloads: - - single_cpu - - multi_cpu + - dhrystone.yaml - name: Float weight: 0.3 - algorithm: geometric mean + formula: geometric mean metrics: - - spec: dhrystone.yaml - workloads: - - single_cpu - - multi_cpu + - whetstone.yaml - name: Memory weight: 0.2 - algorithm: geometric mean + formula: geometric mean metrics: - - spec: ramspeed.yaml - workloads: - - int: [add, average, copy, scale, triad] - - float: [add, average, copy, scale, triad] + - ramspeed.yaml - name: DPI weight: 0.1 - algorithm: geometric mean + formula: geometric mean metrics: - - spec: dpi.yaml - workloads: - - bps - - pps + - dpi.yaml - name: SSL weight: 0.1 - algorithm: geometric mean + formula: geometric mean metrics: - - spec: ssl.yaml - workloads: - - aes_128_cbc: [512, 1024, 2048, 4096] - - rsa_sig: [16, 64, 256, 1024, 8192] + - ssl.yaml diff --git a/tests/data/benchmarks/QPI/fake-qpi.yaml b/tests/data/benchmarks/QPI/fake-qpi.yaml index d75c6568..aa1097f4 100644 --- a/tests/data/benchmarks/QPI/fake-qpi.yaml +++ b/tests/data/benchmarks/QPI/fake-qpi.yaml @@ -1,9 +1,9 @@ name: Fake QPI description: a fake QPI producing random result -algorithm: weighted arithmetic mean +formula: weighted arithmetic mean sections: - name: Fake Section weight: 0.5 - algorithm: geometric mean + formula: geometric mean metrics: - - fake_metric.yaml + - fake-metric.yaml diff --git a/tests/data/benchmarks/metric/dhrystone.yaml b/tests/data/benchmarks/metric/dhrystone.yaml index b0d55ed2..220b7841 100644 --- a/tests/data/benchmarks/metric/dhrystone.yaml +++ b/tests/data/benchmarks/metric/dhrystone.yaml @@ -1,7 +1,9 @@ name: dhrystone description: > - a synthetic computing benchmark program intended to be representative of - system (integer) programming + A synthetic computing benchmark program intended to be representative of + system (integer) programming. +links: + - https://en.wikipedia.org/wiki/Dhrystone workloads: - single_cpu - multi_cpu diff --git a/tests/data/benchmarks/metric/whetstone.yaml b/tests/data/benchmarks/metric/whetstone.yaml index d83680c4..448c9645 100644 --- a/tests/data/benchmarks/metric/whetstone.yaml +++ b/tests/data/benchmarks/metric/whetstone.yaml @@ -1,5 +1,10 @@ -name: dhrystone -description: a synthetic benchmark for evaluating the performance of computers +name: whetstone +description: > + A synthetic benchmark for evaluating the performance of computers. + The Whetstone benchmark primarily measures the floating-point arithmetic + performance. +links: + - https://en.wikipedia.org/wiki/Whetstone_(benchmark) workloads: - single_cpu - multi_cpu diff --git a/tests/unit/runner/plan_test.py b/tests/unit/loader/plan_test.py index 7b3611d1..6aab5e8a 100644 --- a/tests/unit/runner/plan_test.py +++ b/tests/unit/loader/plan_test.py @@ -10,11 +10,14 @@ import pytest from qtip.base.constant import PropName -from qtip.runner.plan import Plan +from qtip.loader.plan import Plan, QPISpec def test_init(plan): assert plan.name == 'fake plan' + assert isinstance(plan.content, dict) + for qpi in plan.qpis: + assert isinstance(qpi, QPISpec) with pytest.raises(TypeError) as excinfo: Plan() @@ -36,3 +39,5 @@ 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 diff --git a/tests/unit/loader/qpi_test.py b/tests/unit/loader/qpi_test.py index c0d4b377..4b3fd4d0 100644 --- a/tests/unit/loader/qpi_test.py +++ b/tests/unit/loader/qpi_test.py @@ -9,7 +9,7 @@ import pytest -from qtip.base.constant import AlgoName, PropName +from qtip.base.constant import FormulaName, PropName from qtip.loader.qpi import QPISpec QPI_SPEC = 'compute.yaml' @@ -42,10 +42,10 @@ def test_list_all(benchmarks_root): def test_content(qpi_spec): content = qpi_spec.content assert PropName.DESCRIPTION in content - assert PropName.ALGORITHM in content + assert PropName.FORMULA in content assert PropName.SECTIONS in content - assert content[PropName.ALGORITHM] in AlgoName.__dict__.values() + assert content[PropName.FORMULA] in FormulaName.__dict__.values() sections = content[PropName.SECTIONS] assert isinstance(sections, list) for section in sections: |