2013-09-21 22:27:41 +00:00
|
|
|
import code
|
|
|
|
import unittest
|
|
|
|
import pcbnew
|
2014-02-04 21:16:32 +00:00
|
|
|
import pdb
|
2013-09-21 22:27:41 +00:00
|
|
|
|
|
|
|
class TestPCBLoad(unittest.TestCase):
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
self.pcb = pcbnew.LoadBoard("data/complex_hierarchy.kicad_pcb")
|
2018-08-04 15:11:45 +00:00
|
|
|
|
2013-09-21 22:27:41 +00:00
|
|
|
def test_pcb_load(self):
|
2018-08-04 15:11:45 +00:00
|
|
|
self.assertNotEqual(self.pcb,None)
|
2013-09-21 22:27:41 +00:00
|
|
|
|
|
|
|
def test_pcb_track_count(self):
|
2018-08-04 15:11:45 +00:00
|
|
|
tracks = list(self.pcb.GetTracks())
|
|
|
|
self.assertEqual(len(tracks),361)
|
2013-09-21 22:27:41 +00:00
|
|
|
|
|
|
|
def test_pcb_modules(self):
|
2020-11-13 23:03:36 +00:00
|
|
|
modules = list(self.pcb.GetFootprints())
|
2013-09-21 22:27:41 +00:00
|
|
|
self.assertEqual(len(modules), 72)
|
|
|
|
|
|
|
|
def test_pcb_module_references(self):
|
2020-10-09 08:41:11 +00:00
|
|
|
board_refs = list(module.GetReference() for
|
2020-11-13 23:03:36 +00:00
|
|
|
module in self.pcb.GetFootprints())
|
2018-08-04 15:11:45 +00:00
|
|
|
|
2020-10-09 08:41:11 +00:00
|
|
|
known_refs = [u'P1', u'P3', u'C2', u'C1', u'D1', u'Q3', u'Q5', u'Q7',
|
2018-08-04 15:11:45 +00:00
|
|
|
u'Q6', u'Q1', u'Q2', u'Q4', u'Q8', u'P2', u'U1', u'U4',
|
2020-10-09 08:41:11 +00:00
|
|
|
u'P4', u'P5', u'P6', u'U3', u'R9', u'R15', u'RV1', u'RV2',
|
|
|
|
u'C3', u'C4', u'C5', u'C6', u'C7', u'C8', u'C9', u'D2',
|
|
|
|
u'D3', u'D4', u'D5', u'D6', u'D7', u'R3', u'R4', u'R5',
|
|
|
|
u'R6', u'R7', u'R8', u'R10', u'R11', u'R12', u'R13',
|
|
|
|
u'R14', u'R16', u'R17', u'R18', u'R19', u'R20', u'R21',
|
|
|
|
u'R22', u'MIRE', u'C10', u'C11',
|
|
|
|
u'U2', u'C14', u'C12', u'R23', u'R24', u'D9', u'D8', u'R25',
|
2018-08-04 15:11:45 +00:00
|
|
|
u'R26', u'R27', u'R28']
|
|
|
|
|
|
|
|
for ref in known_refs:
|
|
|
|
self.assertTrue(ref in board_refs)
|
|
|
|
|
2013-09-21 22:27:41 +00:00
|
|
|
def test_pcb_netcount(self):
|
2018-08-04 15:11:45 +00:00
|
|
|
self.assertEqual(self.pcb.GetNetCount(),51)
|
2013-09-21 22:27:41 +00:00
|
|
|
|
2020-10-09 08:41:11 +00:00
|
|
|
def test_pcb_shapes(self):
|
|
|
|
drawings = list(self.pcb.GetDrawings())
|
|
|
|
edge_cuts = [d for d in drawings if d.GetLayer() == pcbnew.Edge_Cuts]
|
|
|
|
coordinates = [[list(edge.GetStart()), list(edge.GetEnd())] for edge in edge_cuts]
|
|
|
|
expected_coordinates = [
|
|
|
|
[[88265000, 51816000], [188595000, 51816000]],
|
|
|
|
[[88265000, 131826000], [88265000, 51816000]],
|
|
|
|
[[188595000, 51816000], [188595000, 131826000]],
|
|
|
|
[[188595000, 131826000], [88265000, 131826000]]
|
|
|
|
]
|
|
|
|
self.assertEqual(sorted(coordinates), sorted(expected_coordinates))
|
|
|
|
|
|
|
|
def test_pcb_text(self):
|
|
|
|
drawings = list(self.pcb.GetDrawings())
|
|
|
|
text = [d for d in drawings if d.GetClass() == "PTEXT"]
|
|
|
|
self.verify_text(text[0], 173355000, 68453000, pcbnew.F_Cu,
|
|
|
|
u'Actionneur\nPiezo New Amp\nV02')
|
|
|
|
self.verify_text(text[1], 176149000, 64643000, pcbnew.B_Cu,
|
|
|
|
u'Actionneur\nPiezo New Amp\nV02')
|
|
|
|
|
2020-11-21 11:26:57 +00:00
|
|
|
def test_text_as_segments(self):
|
|
|
|
footprint = self.pcb.FindFootprintByReference("U1")
|
|
|
|
reference = footprint.Reference()
|
|
|
|
segments = [[p.x, p.y] for p in reference.TransformToSegmentList()]
|
|
|
|
expected_segments = [
|
2022-01-02 20:23:17 +00:00
|
|
|
[141901333, 69123378], [143340666, 69123378], [143340666, 69123378],
|
|
|
|
[143510000, 69068949], [143510000, 69068949], [143594666, 69014521],
|
|
|
|
[143594666, 69014521], [143679333, 68905663], [143679333, 68905663],
|
|
|
|
[143679333, 68687949], [143679333, 68687949], [143594666, 68579092],
|
|
|
|
[143594666, 68579092], [143510000, 68524663], [143510000, 68524663],
|
|
|
|
[143340666, 68470235], [143340666, 68470235], [141901333, 68470235],
|
|
|
|
[143679333, 67427928], [143679333, 68081071], [143679333, 67754500],
|
|
|
|
[141901333, 67754500], [141901333, 67754500], [142155333, 67863357],
|
|
|
|
[142155333, 67863357], [142324666, 67972214], [142324666, 67972214],
|
|
|
|
[142409333, 68081071]
|
2020-11-21 11:26:57 +00:00
|
|
|
]
|
|
|
|
self.assertEqual(segments, expected_segments)
|
|
|
|
|
2020-10-09 08:41:11 +00:00
|
|
|
def verify_text(self, text, x, y, layer, s):
|
|
|
|
self.assertEquals(list(text.GetPosition()), [x, y])
|
|
|
|
self.assertEquals(text.GetLayer(), layer)
|
|
|
|
self.assertEquals(text.GetText(), s)
|
|
|
|
|
2013-09-21 22:27:41 +00:00
|
|
|
#def test_interactive(self):
|
2018-08-04 15:11:45 +00:00
|
|
|
# code.interact(local=locals())
|
2013-09-21 22:27:41 +00:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|