KiCad PCB EDA Suite
Loading...
Searching...
No Matches
board_expectations.h
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version 3
9 * of the License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, you may find one here:
18 * http://www.gnu.org/licenses/gpl-3.0.html
19 * or you may search the http://www.gnu.org website for the version 3 license,
20 * or you may write to the Free Software Foundation, Inc.,
21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
22 */
23
24#pragma once
25
26
27#include <memory>
28#include <string>
29#include <vector>
30
31#include <json_common.h>
32
33
34class BOARD;
35
36namespace KI_TEST
37{
38
43{
44public:
45 // This class can be handled via the base class pointer
46 virtual ~BOARD_EXPECTATION() = default;
47
48 virtual void RunTest( const BOARD& aBrd ) const = 0;
49
50 virtual std::string GetName() const = 0;
51
56 void SetComment( std::string aComment ) { m_Comment = std::move( aComment ); }
57 const std::string& GetComment() const { return m_Comment; }
58
59private:
60 std::string m_Comment;
61};
62
63
65{
66public:
72 {
74 std::string m_TestName;
76 std::vector<std::string> m_Tags;
78 const nlohmann::json& m_TestJson;
79 };
80
81 BOARD_EXPECTATION_TEST( const std::string& aBrdName ) :
82 m_BrdName( aBrdName )
83 {
84 }
85
89 void RunTest( const BOARD& aBrd ) const;
90
91 static std::unique_ptr<BOARD_EXPECTATION_TEST> CreateFromJson( const std::string& aBrdName,
92 const nlohmann::json& aBrdExpectations );
93
102 static std::vector<DESCRIPTOR> ExtractExpectationTestsFromJson( const nlohmann::json& aExpectationArray );
103
107 static void RunFromRef( const std::string& aBrdName, const BOARD& aBoard,
108 const BOARD_EXPECTATION_TEST::DESCRIPTOR& aExpectationTestRef );
109
110private:
111 std::unique_ptr<BOARD_EXPECTATION> m_expectation;
112 std::string m_BrdName;
113 bool m_skip = false;
114};
115
116} // namespace KI_TEST
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:323
BOARD_EXPECTATION_TEST(const std::string &aBrdName)
static std::unique_ptr< BOARD_EXPECTATION_TEST > CreateFromJson(const std::string &aBrdName, const nlohmann::json &aBrdExpectations)
static std::vector< DESCRIPTOR > ExtractExpectationTestsFromJson(const nlohmann::json &aExpectationArray)
Extracts expectation tests from the given JSON array and returns a list of test references that can b...
void RunTest(const BOARD &aBrd) const
Runs the test against the given board.
std::unique_ptr< BOARD_EXPECTATION > m_expectation
static void RunFromRef(const std::string &aBrdName, const BOARD &aBoard, const BOARD_EXPECTATION_TEST::DESCRIPTOR &aExpectationTestRef)
Constructs a BOARD_EXPECTATION_TEST from the given JSON definition, and runs it on the given board.
A single expectation about a board, which can be run as a test against a parsed BOARD.
virtual std::string GetName() const =0
void SetComment(std::string aComment)
Set a comment to be included in the test output for this expectation, which can be used to provide mo...
const std::string & GetComment() const
virtual void RunTest(const BOARD &aBrd) const =0
virtual ~BOARD_EXPECTATION()=default
Lightweight descriptor for a BOARD_EXPECTATION_TEST, which can be used to refer to the test unambiguo...
std::string m_TestName
If the test has a name, it's that, else an index - this is for naming the test for filtering.
const nlohmann::json & m_TestJson
Handy ref to the JSON entry for this expectations test, which saves looking it up again.
std::vector< std::string > m_Tags
Tags associated with the test, which can be used for filtering.