mirror of
https://gitlab.com/kicad/code/kicad.git
synced 2024-11-24 19:45:05 +00:00
225 lines
7.7 KiB
C++
225 lines
7.7 KiB
C++
/*
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
*
|
|
* Copyright (C) 2024 KiCad Developers, see AUTHORS.txt for contributors.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, you may find one here:
|
|
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
|
* or you may search the http://www.gnu.org website for the version 2 license,
|
|
* or you may write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
|
*/
|
|
|
|
#include <qa_utils/wx_utils/unit_test_utils.h>
|
|
#include <pcbnew_utils/board_test_utils.h>
|
|
#include <board.h>
|
|
#include <board_design_settings.h>
|
|
#include <pad.h>
|
|
#include <pcb_track.h>
|
|
#include <footprint.h>
|
|
#include <zone.h>
|
|
#include <drc/drc_item.h>
|
|
#include <settings/settings_manager.h>
|
|
#include <tools/multichannel_tool.h>
|
|
#include <connectivity/topo_match.h>
|
|
|
|
struct MULTICHANNEL_TEST_FIXTURE
|
|
{
|
|
MULTICHANNEL_TEST_FIXTURE() : m_settingsManager( true /* headless */ ) {}
|
|
|
|
SETTINGS_MANAGER m_settingsManager;
|
|
std::unique_ptr<BOARD> m_board;
|
|
};
|
|
|
|
class MOCK_TOOLS_HOLDER : public TOOLS_HOLDER
|
|
{
|
|
public:
|
|
MOCK_TOOLS_HOLDER(){};
|
|
~MOCK_TOOLS_HOLDER(){};
|
|
|
|
virtual wxWindow* GetToolCanvas() const override { return nullptr; }
|
|
};
|
|
|
|
BOOST_FIXTURE_TEST_SUITE( MultichannelTool, MULTICHANNEL_TEST_FIXTURE )
|
|
|
|
RULE_AREA* findRuleAreaByPartialName( MULTICHANNEL_TOOL* aTool, const wxString& aName )
|
|
{
|
|
for( RULE_AREA& ra : aTool->GetData()->m_areas )
|
|
{
|
|
if( ra.m_ruleName.Contains( ( aName ) ) )
|
|
return &ra;
|
|
}
|
|
|
|
return nullptr;
|
|
}
|
|
|
|
|
|
BOOST_FIXTURE_TEST_CASE( MultichannelToolRegressions, MULTICHANNEL_TEST_FIXTURE )
|
|
{
|
|
using TMATCH::CONNECTION_GRAPH;
|
|
|
|
std::vector<wxString> tests = { "vme-wren" };
|
|
|
|
for( const wxString& relPath : tests )
|
|
{
|
|
KI_TEST::LoadBoard( m_settingsManager, relPath, m_board );
|
|
|
|
TOOL_MANAGER toolMgr;
|
|
MOCK_TOOLS_HOLDER* toolsHolder = new MOCK_TOOLS_HOLDER;
|
|
|
|
toolMgr.SetEnvironment( m_board.get(), nullptr, nullptr, nullptr, toolsHolder );
|
|
|
|
MULTICHANNEL_TOOL* mtTool = new MULTICHANNEL_TOOL; // TOOL_MANAGER owns the tools
|
|
toolMgr.RegisterTool( mtTool );
|
|
|
|
//RULE_AREAS_DATA* raData = m_parentTool->GetData();
|
|
|
|
mtTool->QuerySheetsAndComponentClasses();
|
|
|
|
auto ruleData = mtTool->GetData();
|
|
|
|
BOOST_TEST_MESSAGE( wxString::Format( "RA multichannel sheets = %d",
|
|
static_cast<int>( ruleData->m_areas.size() ) ) );
|
|
|
|
BOOST_CHECK_EQUAL( ruleData->m_areas.size(), 72 );
|
|
|
|
int cnt = 0;
|
|
|
|
ruleData->m_replaceExisting = true;
|
|
|
|
for( RULE_AREA& ra : ruleData->m_areas )
|
|
{
|
|
if( ra.m_sheetName == wxT( "io_driver.kicad_sch" )
|
|
|| ra.m_sheetName == wxT( "pp_driver_2x.kicad_sch" ) )
|
|
{
|
|
ra.m_generateEnabled = true;
|
|
cnt++;
|
|
}
|
|
}
|
|
|
|
BOOST_TEST_MESSAGE( wxString::Format( "Autogenerating %d RAs", cnt ) );
|
|
|
|
TOOL_EVENT dummyEvent;
|
|
|
|
mtTool->AutogenerateRuleAreas( dummyEvent );
|
|
mtTool->FindExistingRuleAreas();
|
|
|
|
int n_areas_io = 0, n_areas_pp = 0, n_areas_other = 0;
|
|
|
|
BOOST_TEST_MESSAGE( wxString::Format( "Found %d RAs after commit",
|
|
static_cast<int>(ruleData->m_areas.size() ) ) );
|
|
|
|
for( const RULE_AREA& ra : ruleData->m_areas )
|
|
{
|
|
BOOST_TEST_MESSAGE( wxString::Format( "SN '%s'", ra.m_ruleName ) );
|
|
|
|
if( ra.m_ruleName.Contains( wxT( "io_drivers_fp" ) ) )
|
|
{
|
|
n_areas_io++;
|
|
BOOST_CHECK_EQUAL( ra.m_raFootprints.size(), 31 );
|
|
}
|
|
else if( ra.m_ruleName.Contains( wxT( "io_drivers_pp" ) ) )
|
|
{
|
|
n_areas_pp++;
|
|
BOOST_CHECK_EQUAL( ra.m_raFootprints.size(), 11 );
|
|
}
|
|
else
|
|
{
|
|
n_areas_other++;
|
|
}
|
|
}
|
|
|
|
BOOST_TEST_MESSAGE( wxString::Format( "IO areas=%d, PP areas=%d, others=%d",
|
|
n_areas_io, n_areas_pp, n_areas_other ) );
|
|
|
|
BOOST_CHECK_EQUAL( n_areas_io, 16 );
|
|
BOOST_CHECK_EQUAL( n_areas_pp, 16 );
|
|
BOOST_CHECK_EQUAL( n_areas_other, 0 );
|
|
|
|
const std::vector<wxString> rulesToTest = { wxT( "io_drivers_fp" ),
|
|
wxT( "io_drivers_pp" ) };
|
|
|
|
for( const wxString& ruleName : rulesToTest )
|
|
{
|
|
for( const RULE_AREA& refArea : ruleData->m_areas )
|
|
{
|
|
if( !refArea.m_ruleName.Contains( ruleName ) )
|
|
continue;
|
|
|
|
BOOST_TEST_MESSAGE( wxString::Format( "REF AREA: '%s'", refArea.m_ruleName ) );
|
|
|
|
for( const RULE_AREA& targetArea : ruleData->m_areas )
|
|
{
|
|
if( targetArea.m_area == refArea.m_area )
|
|
continue;
|
|
|
|
if( !targetArea.m_ruleName.Contains( ruleName ) )
|
|
continue;
|
|
|
|
auto cgRef = CONNECTION_GRAPH::BuildFromFootprintSet( refArea.m_raFootprints );
|
|
auto cgTarget =
|
|
CONNECTION_GRAPH::BuildFromFootprintSet( targetArea.m_raFootprints );
|
|
|
|
TMATCH::COMPONENT_MATCHES result;
|
|
|
|
CONNECTION_GRAPH::STATUS status =
|
|
cgRef->FindIsomorphism( cgTarget.get(), result );
|
|
|
|
BOOST_TEST_MESSAGE( wxString::Format(
|
|
"topo match: '%s' [%d] -> '%s' [%d] result %d",
|
|
refArea.m_ruleName.c_str().AsChar(),
|
|
static_cast<int>( refArea.m_raFootprints.size() ),
|
|
targetArea.m_ruleName.c_str().AsChar(),
|
|
static_cast<int>( targetArea.m_raFootprints.size() ), status ) );
|
|
|
|
for( const auto& iter : result )
|
|
{
|
|
BOOST_TEST_MESSAGE( wxString::Format( "%s : %s",
|
|
iter.second->GetReference(),
|
|
iter.first->GetReference() ) );
|
|
}
|
|
|
|
BOOST_CHECK_EQUAL( status, TMATCH::CONNECTION_GRAPH::ST_OK );
|
|
}
|
|
}
|
|
}
|
|
|
|
auto refArea = findRuleAreaByPartialName( mtTool, wxT( "io_drivers_fp/bank3/io78/" ) );
|
|
|
|
BOOST_ASSERT( refArea );
|
|
|
|
const std::vector<wxString> targetAreaNames( { wxT( "io_drivers_fp/bank2/io78/" ),
|
|
wxT( "io_drivers_fp/bank1/io78/" ),
|
|
wxT( "io_drivers_fp/bank0/io01/" ) } );
|
|
|
|
for( const wxString& targetRaName : targetAreaNames )
|
|
{
|
|
auto targetRA = findRuleAreaByPartialName( mtTool, targetRaName );
|
|
|
|
BOOST_ASSERT( targetRA != nullptr );
|
|
|
|
BOOST_TEST_MESSAGE( wxString::Format( "Clone to: %s", targetRA->m_ruleName ) );
|
|
|
|
ruleData->m_compatMap[targetRA].m_doCopy = true;
|
|
}
|
|
|
|
int result = mtTool->RepeatLayout( TOOL_EVENT(), refArea->m_area );
|
|
|
|
BOOST_ASSERT( result >= 0 );
|
|
}
|
|
}
|
|
|
|
|
|
BOOST_AUTO_TEST_SUITE_END()
|