summaryrefslogtreecommitdiff
path: root/gerbonara/tests
diff options
context:
space:
mode:
authorjaseg <git@jaseg.de>2023-11-14 21:43:22 +0100
committerjaseg <git@jaseg.de>2023-11-14 21:54:04 +0100
commitea4c28e307622fd575d95d9d81b29820c6feff99 (patch)
tree29f093a15001cff7fb7c5189fa9db101de2aa36e /gerbonara/tests
parent51ef4882a16cecb29bb643100b432b22e1f3f76f (diff)
downloadgerbonara-ea4c28e307622fd575d95d9d81b29820c6feff99.tar.gz
gerbonara-ea4c28e307622fd575d95d9d81b29820c6feff99.tar.bz2
gerbonara-ea4c28e307622fd575d95d9d81b29820c6feff99.zip
Make new test files pass
Diffstat (limited to 'gerbonara/tests')
-rw-r--r--gerbonara/tests/test_excellon.py9
-rw-r--r--gerbonara/tests/test_rs274x.py68
2 files changed, 71 insertions, 6 deletions
diff --git a/gerbonara/tests/test_excellon.py b/gerbonara/tests/test_excellon.py
index cd0960f..4dcedd6 100644
--- a/gerbonara/tests/test_excellon.py
+++ b/gerbonara/tests/test_excellon.py
@@ -50,6 +50,15 @@ REFERENCE_FILES = {
'diptrace/keyboard.drl': (None, 'diptrace/keyboard_Bottom.gbr'),
'zuken-emulated/Drill/8seg_Driver__routed_Drill_thru_plt.fdr/8seg_Driver__routed_Drill_thru_plt.fdr': (('inch', 'trailing', 4), 'zuken-emulated/Gerber/Conductive-1.fph'),
'zuken-emulated/Drill/8seg_Driver__routed_Drill_thru_nplt.fdr': (('inch', 'trailing', 4), None),
+ 'p-cad/ZXINET.DRL': (None, None),
+ 'kicad-x2-tests/nox2ap/Flashpads-NPTH.drl': (None, None),
+ 'kicad-x2-tests/nox2ap/Flashpads-PTH.drl': (None, None),
+ 'kicad-x2-tests/nox2noap/Flashpads-NPTH.drl': (None, None),
+ 'kicad-x2-tests/nox2noap/Flashpads-PTH.drl': (None, None),
+ 'kicad-x2-tests/x2ap/Flashpads-NPTH.drl': (None, None),
+ 'kicad-x2-tests/x2ap/Flashpads-PTH.drl': (None, None),
+ 'kicad-x2-tests/x2noap/Flashpads-NPTH.drl': (None, None),
+ 'kicad-x2-tests/x2noap/Flashpads-PTH.drl': (None, None),
}
@filter_syntax_warnings
diff --git a/gerbonara/tests/test_rs274x.py b/gerbonara/tests/test_rs274x.py
index f85b09f..8f0da70 100644
--- a/gerbonara/tests/test_rs274x.py
+++ b/gerbonara/tests/test_rs274x.py
@@ -248,6 +248,58 @@ REFERENCE_FILES = [ l.strip() for l in '''
zuken-emulated/Gerber/Resist-B.fph
zuken-emulated/Gerber/Conductive-1.fph
zuken-emulated/Gerber/Conductive-2.fph
+ p-cad/ZXINET.GBL
+ p-cad/ZXINET.GBO
+ p-cad/ZXINET.GBS
+ p-cad/ZXINET.GKO
+ p-cad/ZXINET.GTL
+ p-cad/ZXINET.GTO
+ p-cad/ZXINET.GTS
+ fab-3000/bl
+ fab-3000/bo
+ fab-3000/bs
+ fab-3000/ko
+ fab-3000/tl
+ fab-3000/to
+ fab-3000/ts
+ fab-3000/drl
+ kicad-x2-tests/nox2ap/Flashpads-B_Cu.gbr
+ kicad-x2-tests/nox2ap/Flashpads-B_Mask.gbr
+ kicad-x2-tests/nox2ap/Flashpads-B_Paste.gbr
+ kicad-x2-tests/nox2ap/Flashpads-B_Silkscreen.gbr
+ kicad-x2-tests/nox2ap/Flashpads-Edge_Cuts.gbr
+ kicad-x2-tests/nox2ap/Flashpads-F_Cu.gbr
+ kicad-x2-tests/nox2ap/Flashpads-F_Mask.gbr
+ kicad-x2-tests/nox2ap/Flashpads-F_Paste.gbr
+ kicad-x2-tests/nox2ap/Flashpads-F_Silkscreen.gbr
+ kicad-x2-tests/nox2noap/Flashpads-B_Cu.gbr
+ kicad-x2-tests/nox2noap/Flashpads-B_Mask.gbr
+ kicad-x2-tests/nox2noap/Flashpads-B_Paste.gbr
+ kicad-x2-tests/nox2noap/Flashpads-B_Silkscreen.gbr
+ kicad-x2-tests/nox2noap/Flashpads-Edge_Cuts.gbr
+ kicad-x2-tests/nox2noap/Flashpads-F_Cu.gbr
+ kicad-x2-tests/nox2noap/Flashpads-F_Mask.gbr
+ kicad-x2-tests/nox2noap/Flashpads-F_Paste.gbr
+ kicad-x2-tests/nox2noap/Flashpads-F_Silkscreen.gbr
+ kicad-x2-tests/x2ap/Flashpads-B_Cu.gbr
+ kicad-x2-tests/x2ap/Flashpads-B_Mask.gbr
+ kicad-x2-tests/x2ap/Flashpads-B_Paste.gbr
+ kicad-x2-tests/x2ap/Flashpads-B_Silkscreen.gbr
+ kicad-x2-tests/x2ap/Flashpads-Edge_Cuts.gbr
+ kicad-x2-tests/x2ap/Flashpads-F_Cu.gbr
+ kicad-x2-tests/x2ap/Flashpads-F_Mask.gbr
+ kicad-x2-tests/x2ap/Flashpads-F_Paste.gbr
+ kicad-x2-tests/x2ap/Flashpads-F_Silkscreen.gbr
+ kicad-x2-tests/x2noap/Flashpads-B_Cu.gbr
+ kicad-x2-tests/x2noap/Flashpads-B_Mask.gbr
+ kicad-x2-tests/x2noap/Flashpads-B_Paste.gbr
+ kicad-x2-tests/x2noap/Flashpads-B_Silkscreen.gbr
+ kicad-x2-tests/x2noap/Flashpads-Edge_Cuts.gbr
+ kicad-x2-tests/x2noap/Flashpads-F_Cu.gbr
+ kicad-x2-tests/x2noap/Flashpads-F_Mask.gbr
+ kicad-x2-tests/x2noap/Flashpads-F_Paste.gbr
+ kicad-x2-tests/x2noap/Flashpads-F_Silkscreen.gbr
+ gerbv.gbr
'''.splitlines() if l ]
MIN_REFERENCE_FILES = [
@@ -501,8 +553,6 @@ def test_svg_export_gerber(reference, tmpfile):
assert mean < 1.2e-3
assert hist[3:].sum() < 1e-3*hist.size
-# FIXME test svg margin, bounding box computation
-
@filter_syntax_warnings
@pytest.mark.parametrize('reference', REFERENCE_FILES, indirect=True)
def test_bounding_box(reference, tmpfile):
@@ -519,6 +569,12 @@ def test_bounding_box(reference, tmpfile):
grb = GerberFile.open(reference)
+ if reference.match(f'fab-3000/*'):
+ # These files have the board outline plotted in clear polarity. Change them to dark to not confuse our matching
+ # code below.
+ for prim in grb.objects:
+ prim.polarity_dark = True
+
if grb.is_empty:
pytest.skip()
@@ -542,10 +598,10 @@ def test_bounding_box(reference, tmpfile):
# Check that all margins are completely black and that the content touches the margins. Allow for some tolerance to
# allow for antialiasing artifacts and for things like very thin features.
- assert margin_px-2 <= col_prefix <= margin_px+2
- assert margin_px-2 <= col_suffix <= margin_px+2
- assert margin_px-2 <= row_prefix <= margin_px+2
- assert margin_px-2 <= row_suffix <= margin_px+2
+ assert margin_px-3 <= col_prefix <= margin_px+3
+ assert margin_px-3 <= col_suffix <= margin_px+3
+ assert margin_px-3 <= row_prefix <= margin_px+3
+ assert margin_px-3 <= row_suffix <= margin_px+3
@filter_syntax_warnings
def test_syntax_error():