Nektar++
MetricExecutionTime.h
Go to the documentation of this file.
1///////////////////////////////////////////////////////////////////////////////
2//
3// File: MetricExecutionTime.h
4//
5// For more information, please see: http://www.nektar.info
6//
7// The MIT License
8//
9// Copyright (c) 2006 Division of Applied Mathematics, Brown University (USA),
10// Department of Aeronautics, Imperial College London (UK), and Scientific
11// Computing and Imaging Institute, University of Utah (USA).
12//
13// Permission is hereby granted, free of charge, to any person obtaining a
14// copy of this software and associated documentation files (the "Software"),
15// to deal in the Software without restriction, including without limitation
16// the rights to use, copy, modify, merge, publish, distribute, sublicense,
17// and/or sell copies of the Software, and to permit persons to whom the
18// Software is furnished to do so, subject to the following conditions:
19//
20// The above copyright notice and this permission notice shall be included
21// in all copies or substantial portions of the Software.
22//
23// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
24// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
26// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
28// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
29// DEALINGS IN THE SOFTWARE.
30//
31// Description: Implementation of the execution time metric. A test will fail
32// if the execution time of the test falls outside of an assigned tolerance.
33//
34///////////////////////////////////////////////////////////////////////////////
35
36#ifndef NEKTAR_TESTS_METRICEXECUTIONTIME_H
37#define NEKTAR_TESTS_METRICEXECUTIONTIME_H
38
39#include <Metric.h>
40
41#include <regex>
42#include <vector>
43
44namespace Nektar
45{
46/**
47 * @brief Data structure for an execution time field value.
48 */
50{
52 {
53 }
54
55 MetricExecutionTimeFieldValue(std::string value) : m_value(value)
56 {
57 }
58
59 /// The value to match. Defaults to empty string.
60 std::string m_value = "";
61 /// Indicates whether the metric should be skipped. Defaults to false.
62 bool m_skip = false;
63 /// The tolerance to use for checking the execution time. Defaults to 5.0.
64 double m_tolerance = 5.0;
65};
66
67/**
68 * @brief Metric that finds the execution time in an output and tests it against
69 * an accepted value and tolerance.
70 */
72{
73public:
75 {
76 }
77
78 static MetricSharedPtr create(TiXmlElement *metric, bool generate)
79 {
80 return MetricSharedPtr(new MetricExecutionTime(metric, generate));
81 }
82
83 static std::string type;
84
85protected:
86 /// Regex used to match an execution time in a test output.
87 std::regex m_regex;
88 /// Stores each execution time found in the test output.
90 /// If true, use stderr for testing/generation instead of stdout.
91 bool m_useStderr = false;
92
93 MetricExecutionTime(TiXmlElement *metric, bool generate);
94
95 bool v_Test(std::istream &pStdout, std::istream &pStderr) override;
96 void v_Generate(std::istream &pStdout, std::istream &pStderr) override;
97};
98} // namespace Nektar
99
100#endif
Metric that finds the execution time in an output and tests it against an accepted value and toleranc...
std::regex m_regex
Regex used to match an execution time in a test output.
bool v_Test(std::istream &pStdout, std::istream &pStderr) override
Test output against a regular expression and its expected value.
bool m_useStderr
If true, use stderr for testing/generation instead of stdout.
void v_Generate(std::istream &pStdout, std::istream &pStderr) override
Generate an accepted execution time value using a test output or error stream.
static MetricSharedPtr create(TiXmlElement *metric, bool generate)
MetricExecutionTime(TiXmlElement *metric, bool generate)
Construct a new MetricExecutionTime object.
MetricExecutionTimeFieldValue m_match
Stores each execution time found in the test output.
Base class for all metrics. Metric represents a test metric that can be used to evaluate the function...
Definition: Metric.h:65
std::shared_ptr< Metric > MetricSharedPtr
A shared pointer to an EquationSystem object.
Definition: Metric.h:124
Data structure for an execution time field value.
double m_tolerance
The tolerance to use for checking the execution time. Defaults to 5.0.
std::string m_value
The value to match. Defaults to empty string.
bool m_skip
Indicates whether the metric should be skipped. Defaults to false.