1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174
|
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import params
import pytest
"""
Test command "open-project --drc"
"""
@pytest.mark.parametrize("project", [params.EMPTY_PROJECT_LPP_PARAM])
def test_if_project_without_boards_succeeds(cli, project):
cli.add_project(project.dir, as_lppz=project.is_lppz)
# remove all boards
with open(cli.abspath(project.dir + '/boards/boards.lp'), 'w') as f:
f.write('(librepcb_boards)')
code, stdout, stderr = cli.run('open-project', '--drc', project.path)
assert stderr == ''
assert stdout == \
"Open project '{project.path}'...\n" \
"Run DRC...\n" \
"SUCCESS\n".format(project=project)
assert code == 0
@pytest.mark.parametrize("project", [params.PROJECT_WITH_TWO_BOARDS_LPPZ_PARAM])
def test_project_with_two_boards_explicit_one(cli, project):
cli.add_project(project.dir, as_lppz=project.is_lppz)
code, stdout, stderr = cli.run('open-project', '--drc', '--board=copy',
project.path)
assert stderr == ''
assert stdout == \
"Open project '{project.path}'...\n" \
"Run DRC...\n" \
" Board 'copy':\n" \
" Approved messages: 0\n" \
" Non-approved messages: 0\n" \
"SUCCESS\n".format(project=project)
assert code == 0
@pytest.mark.parametrize("project", [params.EMPTY_PROJECT_LPP_PARAM])
def test_board_with_approved_message(cli, project):
cli.add_project(project.dir, as_lppz=project.is_lppz)
# Add a hole with small diameter and the corresponding approval.
with open(cli.abspath(project.dir + '/boards/default/board.lp'), 'r') as f:
board_content = f.read()
board_content = board_content.replace(
'\n)\n',
'\n (hole 82506db2-3323-4732-8480-f3517f10dd44 '
' (diameter 0.1) (stop_mask auto) (lock false)\n'
' (vertex (position 50.0 50.0) (angle 0.0))\n'
' )\n'
')\n'
)
board_content = board_content.replace(
' (design_rule_check\n',
' (design_rule_check\n'
' (approved minimum_drill_diameter_violation\n'
' (hole 82506db2-3323-4732-8480-f3517f10dd44)\n'
' )\n'
)
with open(cli.abspath(project.dir + '/boards/default/board.lp'), 'w') as f:
f.write(board_content)
code, stdout, stderr = cli.run('open-project', '--drc', project.path)
assert stdout == \
"Open project '{project.path}'...\n" \
"Run DRC...\n" \
" Board 'default':\n" \
" Approved messages: 1\n" \
" Non-approved messages: 0\n" \
"SUCCESS\n".format(project=project)
assert code == 0
@pytest.mark.parametrize("project", [params.EMPTY_PROJECT_LPP_PARAM])
def test_board_without_messages(cli, project):
cli.add_project(project.dir, as_lppz=project.is_lppz)
code, stdout, stderr = cli.run('open-project', '--drc', project.path)
assert stderr == ''
assert stdout == \
"Open project '{project.path}'...\n" \
"Run DRC...\n" \
" Board 'default':\n" \
" Approved messages: 0\n" \
" Non-approved messages: 0\n" \
"SUCCESS\n".format(project=project)
assert code == 0
@pytest.mark.parametrize("project", [params.EMPTY_PROJECT_LPP_PARAM])
def test_board_with_nonapproved_message(cli, project):
cli.add_project(project.dir, as_lppz=project.is_lppz)
# Add a hole with small diameter.
with open(cli.abspath(project.dir + '/boards/default/board.lp'), 'r') as f:
board_content = f.read()
board_content = board_content.replace(
'\n)\n',
'\n (hole 82506db2-3323-4732-8480-f3517f10dd44 '
' (diameter 0.1) (stop_mask auto) (lock false)\n'
' (vertex (position 50.0 50.0) (angle 0.0))\n'
' )\n'
')\n'
)
with open(cli.abspath(project.dir + '/boards/default/board.lp'), 'w') as f:
f.write(board_content)
code, stdout, stderr = cli.run('open-project', '--drc', project.path)
assert stderr == " - [WARNING] NPTH drill diameter: 0.1 < 0.25 mm\n"
assert stdout == \
"Open project '{project.path}'...\n" \
"Run DRC...\n" \
" Board 'default':\n" \
" Approved messages: 0\n" \
" Non-approved messages: 1\n" \
"Finished with errors!\n".format(project=project)
assert code == 1
@pytest.mark.parametrize("project", [params.EMPTY_PROJECT_LPP_PARAM])
def test_with_custom_settings(cli, project):
cli.add_project(project.dir, as_lppz=project.is_lppz)
settings = """
(design_rule_check
(min_copper_copper_clearance 0.2)
(min_copper_board_clearance 0.3)
(min_copper_npth_clearance 0.2)
(min_drill_drill_clearance 0.35)
(min_drill_board_clearance 0.5)
(min_silkscreen_stopmask_clearance 0.127)
(min_copper_width 0.2)
(min_annular_ring 0.15)
(min_npth_drill_diameter 0.1234)
(min_pth_drill_diameter 0.25)
(min_npth_slot_width 1.0)
(min_pth_slot_width 0.7)
(min_silkscreen_width 0.1)
(min_silkscreen_text_height 0.8)
(min_outline_tool_diameter 2.0)
(blind_vias_allowed true)
(buried_vias_allowed true)
(allowed_npth_slots single_segment_straight)
(allowed_pth_slots single_segment_straight)
(approvals_version "0.2")
)
"""
with open(cli.abspath('settings.lp'), mode='w') as f:
f.write(settings)
# Add a hole with small diameter.
with open(cli.abspath(project.dir + '/boards/default/board.lp'), 'r') as f:
board_content = f.read()
board_content = board_content.replace(
'\n)\n',
'\n (hole 82506db2-3323-4732-8480-f3517f10dd44 '
' (diameter 0.1) (stop_mask auto) (lock false)\n'
' (vertex (position 50.0 50.0) (angle 0.0))\n'
' )\n'
')\n'
)
with open(cli.abspath(project.dir + '/boards/default/board.lp'), 'w') as f:
f.write(board_content)
code, stdout, stderr = cli.run('open-project',
'--drc',
'--drc-settings', 'settings.lp',
project.path)
assert stderr == " - [WARNING] NPTH drill diameter: 0.1 < 0.1234 mm\n"
assert stdout == \
"Open project '{project.path}'...\n" \
"Run DRC...\n" \
" Board 'default':\n" \
" Approved messages: 0\n" \
" Non-approved messages: 1\n" \
"Finished with errors!\n".format(project=project)
assert code == 1
|