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#include <boost/regex.hpp>
41#include <vector>
42
43namespace Nektar
44{
45/**
46 * @brief Data structure for an execution time field value.
47 */
49{
51 {
52 }
53
54 MetricExecutionTimeFieldValue(std::string value) : m_value(value)
55 {
56 }
57
58 /// The value to match. Defaults to empty string.
59 std::string m_value = "";
60 /// Indicates whether the metric should be skipped. Defaults to false.
61 bool m_skip = false;
62 /// The tolerance to use for checking the execution time. Defaults to 5.0.
63 double m_tolerance = 5.0;
64};
65
66/**
67 * @brief Metric that finds the execution time in an output and tests it against
68 * an accepted value and tolerance.
69 */
71{
72public:
74 {
75 }
76
77 static MetricSharedPtr create(TiXmlElement *metric, bool generate)
78 {
79 return MetricSharedPtr(new MetricExecutionTime(metric, generate));
80 }
81
82 static std::string type;
83
84protected:
85 /// Regex used to match an execution time in a test output.
86 boost::regex m_regex;
87 /// Stores each execution time found in the test output.
89 /// If true, use stderr for testing/generation instead of stdout.
90 bool m_useStderr = false;
91
92 MetricExecutionTime(TiXmlElement *metric, bool generate);
93
94 virtual bool v_Test(std::istream &pStdout, std::istream &pStderr);
95 virtual void v_Generate(std::istream &pStdout, std::istream &pStderr);
96};
97} // namespace Nektar
98
99#endif
Metric that finds the execution time in an output and tests it against an accepted value and toleranc...
bool m_useStderr
If true, use stderr for testing/generation instead of stdout.
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.
boost::regex m_regex
Regex used to match an execution time in a test output.
virtual void v_Generate(std::istream &pStdout, std::istream &pStderr)
Generate an accepted execution time value using a test output or error stream.
virtual bool v_Test(std::istream &pStdout, std::istream &pStderr)
Test output against a regular expression and its expected value.
Base class for all metrics. Metric represents a test metric that can be used to evaluate the function...
Definition: Metric.h:70
The above copyright notice and this permission notice shall be included.
Definition: CoupledSolver.h:2
std::shared_ptr< Metric > MetricSharedPtr
A shared pointer to an EquationSystem object.
Definition: Metric.h:129
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.