1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00

0030396: Infinite recursion during ShapeFix after BRepAlgoAPI_Cut

Two test cases are added. One for Boolean operation (it is good, because BO has been fixed already), and another for fixshape operation (it causes Draw crash).
This commit is contained in:
msv 2018-12-20 17:10:00 +03:00 committed by apn
parent 6c27a5d993
commit 4473e33655
2 changed files with 58 additions and 0 deletions

View File

@ -0,0 +1,47 @@
puts "========"
puts "0030396: Infinite recursion during ShapeFix after BRepAlgoAPI_Cut"
puts "========"
puts ""
# With this order of tools the operation produced bad result
set list(1) {a_2 a_3 a_4 a_5 a_6 a_7}
# With this order of tools the operation produced good result
set list(2) {a_6 a_2 a_7 a_3 a_4 a_5}
set nbw {33 23 29 0}
set nbf {33 17 23 0}
set nbsh {6 1 1 0}
set nbso {6 1 1 0}
set vol {3.24433 11.1953 7.95093 empty}
set area {25.9962 58.8635 53.1541 empty}
set nameop {common fuse cut cut21}
bfuzzyvalue 1e-2
bnondestructive 1
for {set i 1} { $i <= 2} {incr i} {
restore [locate_data_file bug30396.brep] a
explode a
bclearobjects
bcleartools
baddobjects a_1
eval baddtools $list($i)
bfillds
for {set iop 0} {$iop < 4} {incr iop} {
set oper [lindex $nameop $iop]
bbop r_${i}_$oper $iop
checknbshapes r_${i}_$oper -wire [lindex $nbw $iop] -face [lindex $nbf $iop]\
-solid [lindex $nbso $iop] -shell [lindex $nbsh $iop]
checkprops r_${i}_$oper -v [lindex $vol $iop] -s [lindex $area $iop]
checkshape r_${i}_$oper
if {![regexp "OK" [bopcheck r_${i}_$oper]]} {
puts "Error: result $i of $oper is self-interfered shape"
}
}
}
boptions -default
checkview -display r_1_cut -2d -path ${imagedir}/${test_image}.png

View File

@ -0,0 +1,11 @@
puts "========"
puts "0030396: Infinite recursion during ShapeFix after BRepAlgoAPI_Cut"
puts "========"
puts ""
puts "TODO 30396 ALL:TEST INCOMPLETE"
# The shape bug30396_bad_result.brep has been saved in OCCT 7.3, before BO has been fixed.
restore [locate_data_file bug30396_bad_result.brep] a
# The Draw crashed here
fixshape r a