53 BOOST_TEST_CHECKPOINT(
"Loading schematic " << fn.GetFullPath() );
61 m_manager.LoadProject( pro.GetFullPath() );
75 BOOST_REQUIRE_EQUAL(
m_pi->GetError().IsEmpty(),
true );
80 for(
SCH_SCREEN* screen = screens.GetFirst(); screen; screen = screens.GetNext() )
81 screen->UpdateLocalLibSymbolLinks();
86 if(
m_schematic->RootScreen()->GetFileFormatVersionAtLoad() < 20221002 )
89 if(
m_schematic->RootScreen()->GetFileFormatVersionAtLoad() < 20221110 )
92 if(
m_schematic->RootScreen()->GetFileFormatVersionAtLoad() < 20221206 )
94 for(
SCH_SCREEN* screen = screens.GetFirst(); screen; screen = screens.GetNext() )
95 screen->MigrateSimModels();
98 if( m_schematic->RootScreen()->GetFileFormatVersionAtLoad() < 20230221 )
99 screens.FixLegacyPowerSymbolMismatches();
105 sheet.UpdateAllScreenReferences();
110 std::unordered_set<SCH_SCREEN*> all_screens;
113 all_screens.insert(
path.LastScreen() );
117 m_schematic->ConnectionGraph()->Recalculate( sheets,
true );
124 fn.AppendDir(
"netlists" );
125 fn.AppendDir( aBaseName );
126 fn.SetName( aBaseName );
133template <
typename Exporter>
136 wxFileName netFile =
m_schematic->Project().GetProjectFullName();
139 netFile.SetName( netFile.GetName() +
"_test" );
143 return netFile.GetFullPath();
147template <
typename Exporter>
151 BOOST_TEST_CHECKPOINT(
"Writing netlist " << netlistPath );
154 if( wxFileExists( netlistPath ) )
155 wxRemoveFile( netlistPath );
158 std::unique_ptr<Exporter> exporter = std::make_unique<Exporter>(
m_schematic.get() );
166template <
typename Exporter>
174template <
typename Exporter>
~SCHEMATIC_TEST_FIXTURE()
SETTINGS_MANAGER m_manager
std::unique_ptr< SCHEMATIC > m_schematic
virtual void LoadSchematic(const wxFileName &aFn)
IO_RELEASER< SCH_IO > m_pi
virtual wxFileName SchematicQAPath(const wxString &aBaseName)
A factory which returns an instance of a SCH_IO.
static std::vector< std::pair< SCH_RULE_AREA *, SCH_SCREEN * > > UpdateRuleAreasInScreens(std::unordered_set< SCH_SCREEN * > &screens, KIGFX::SCH_VIEW *view)
Update all rule area connectvity / caches in the given sheet paths.
Container class that holds multiple SCH_SCREEN objects in a hierarchy.
A container for handling SCH_SHEET_PATH objects in a flattened hierarchy.
void UpdateSheetInstanceData(const std::vector< SCH_SHEET_INSTANCE > &aSheetInstances)
Update all of the sheet instance information using aSheetInstances.
void AnnotatePowerSymbols()
Silently annotate the not yet annotated power symbols of the entire hierarchy of the sheet path list.
void UpdateSymbolInstanceData(const std::vector< SCH_SYMBOL_INSTANCE > &aSymbolInstances)
Update all of the symbol instance information using aSymbolInstances.
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
void TestNetlist(const wxString &aBaseName)
virtual void CompareNetlists()=0
virtual unsigned GetNetlistOptions()
virtual wxString GetNetlistPath(bool aTest=false)
A wrapper for reporting to a wxString object.
static const std::string NetlistFileExtension
static const std::string ProjectFileExtension
static const std::string KiCadSchematicFileExtension
void LoadSchematic(SETTINGS_MANAGER &aSettingsManager, const wxString &aRelPath, std::unique_ptr< SCHEMATIC > &aSchematic)
std::string GetEeschemaTestDataDir()
Get the configured location of Eeschema test data.
BOOST_REQUIRE(intersection.has_value()==c.ExpectedIntersection.has_value())
IbisParser parser & reporter
Definition of file extensions used in Kicad.