21#include <boost/test/data/test_case.hpp>
38struct TRACK_CLEANER_TEST_FIXTURE
40 TRACK_CLEANER_TEST_FIXTURE()
43 SETTINGS_MANAGER m_settingsManager;
44 std::unique_ptr<BOARD> m_board;
48struct TEST_DESCRIPTION
53 bool m_RedundantTracks;
54 bool m_DanglingTracks;
59 friend std::ostream&
operator<<( std::ostream& os,
const TEST_DESCRIPTION& aDesc )
69std::vector<TEST_DESCRIPTION> FailedToCleanRegressionTests_tests =
73 {
"issue2904",
false,
false,
false,
true,
false,
false, 9 },
74 {
"issue5093",
false,
false,
false,
false,
true,
false, 117 },
75 {
"issue7004",
false,
true,
false,
false,
false,
true, 25 },
76 {
"issue8883",
true,
true,
true,
true,
false,
true, 81 },
77 {
"issue10916",
false,
false,
true,
false,
false,
false, 0 },
78 {
"issue19574",
false,
false,
true,
false,
false,
false, 2 },
85 boost::unit_test::data::make( FailedToCleanRegressionTests_tests ), entry )
89 m_board->GetConnectivity()->RecalculateRatsnest();
90 m_board->UpdateRatsnestExclusions();
93 toolMgr.
SetEnvironment( m_board.get(),
nullptr,
nullptr,
nullptr,
nullptr );
100 std::vector< std::shared_ptr<CLEANUP_ITEM> > dryRunItems;
101 std::vector< std::shared_ptr<CLEANUP_ITEM> > realRunItems;
103 cleaner.
CleanupBoard(
true, &dryRunItems, entry.m_Shorts,
104 entry.m_RedundantVias,
105 entry.m_RedundantTracks,
106 entry.m_DanglingTracks,
107 entry.m_TracksInPads,
108 entry.m_DanglingVias );
110 cleaner.
CleanupBoard(
true, &realRunItems, entry.m_Shorts,
111 entry.m_RedundantVias,
112 entry.m_RedundantTracks,
113 entry.m_DanglingTracks,
114 entry.m_TracksInPads,
115 entry.m_DanglingVias );
117 if( dryRunItems.size() == entry.m_Expected && realRunItems.size() == entry.m_Expected )
130 std::map<KIID, EDA_ITEM*> itemMap;
131 m_board->FillItemMap( itemMap );
133 for(
const std::shared_ptr<CLEANUP_ITEM>& item : realRunItems )
139 BOOST_ERROR( wxString::Format(
"Track cleaner regression: %s, failed",
147std::vector<wxString> TrackCleanerRegressionTests_tests = {
160 boost::unit_test::data::make( TrackCleanerRegressionTests_tests ), relPath )
164 m_board->GetConnectivity()->RecalculateRatsnest();
165 m_board->UpdateRatsnestExclusions();
168 toolMgr.
SetEnvironment( m_board.get(),
nullptr,
nullptr,
nullptr,
nullptr );
175 std::vector< std::shared_ptr<CLEANUP_ITEM> > dryRunItems;
176 std::vector< std::shared_ptr<CLEANUP_ITEM> > realRunItems;
194 std::vector<DRC_ITEM> violations;
207 [&](
const std::shared_ptr<DRC_ITEM>& aItem,
const VECTOR2I& aPos,
int aLayer,
208 const std::function<
void(
PCB_MARKER* )>& aPathGenerator )
211 violations.push_back( *aItem );
216 if( violations.empty() )
218 BOOST_TEST_MESSAGE( wxString::Format(
"Track cleaner regression: %s, passed", relPath ) );
224 std::map<KIID, EDA_ITEM*> itemMap;
225 m_board->FillItemMap( itemMap );
227 for(
const DRC_ITEM& item : violations )
230 BOOST_ERROR( wxString::Format(
"Track cleaner regression: %s, failed", relPath ) );
constexpr EDA_IU_SCALE pcbIUScale
Container for design settings for a BOARD object.
std::map< int, SEVERITY > m_DRCSeverities
std::shared_ptr< DRC_ENGINE > m_DRCEngine
void RunTests(EDA_UNITS aUnits, bool aReportAllTrackErrors, bool aTestFootprints, BOARD_COMMIT *aCommit=nullptr)
Run the DRC tests.
void SetViolationHandler(DRC_VIOLATION_HANDLER aHandler)
Set an optional DRC violation handler (receives DRC_ITEMs and positions).
void CleanupBoard(bool aDryRun, std::vector< std::shared_ptr< CLEANUP_ITEM > > *aItemsList, bool aCleanVias, bool aRemoveMisConnected, bool aMergeSegments, bool aDeleteUnconnected, bool aDeleteTracksinPad, bool aDeleteDanglingVias, REPORTER *aReporter=nullptr)
the cleanup function.
@ DRCE_LIB_FOOTPRINT_ISSUES
@ DRCE_LIB_FOOTPRINT_MISMATCH
std::ostream & operator<<(std::ostream &aStream, const EDA_TEXT &aText)
void LoadBoard(SETTINGS_MANAGER &aSettingsManager, const wxString &aRelPath, std::unique_ptr< BOARD > &aBoard)
void FillZones(BOARD *m_board)
BOOST_TEST_MESSAGE("\n=== Real-World Polygon PIP Benchmark ===\n"<< formatTable(table))
BOOST_CHECK_EQUAL(result, "25.4")
BOOST_DATA_TEST_CASE_F(TRACK_CLEANER_TEST_FIXTURE, FailedToCleanRegressionTests, boost::unit_test::data::make(FailedToCleanRegressionTests_tests), entry)
VECTOR2< int32_t > VECTOR2I