mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
test bugs modalg_7 bug22821 failed on fillet shape with 5-th edge. Experimentally has been found that reducing of parameter ChFi3d_Builder::tolesp for this task solves the issue. So, as soluton it is proposed to link parameter toleps with parameter range of spine curve. So, production coefficient has been set to pass all tests and 2 teset was extended: tests/blend/complex/A6, tests/bugs/modalg_7/bug22821 first has been extended to test different scaling factors, second has been extended to make fillet on all edges from 12. Additionally: - fixed misusage of tolesp in contexts where tolerance of point in 3d is excepted; In some context usage of tol_esp is irrelevant, because its essentiality - tolerance of the parameter on the 3d curve. So, in such context it has been replaced with new parameter tol3d (with fix value 1.0e-4). Get rid of tolapp3d duplication constant - tol_3d - tolesp = 5.0e-5 * (umax - umin) - tolesp replaced by tolpoint2d/tolpoint3d in several classes. Blend_Walking BRepBlend_SurfRstLineBuilder BRepBlend_RstRstLineBuilder Blend_CSWalking Instead `tolesp` - `tolgui` is employed in contexts where tolerance of guide curve parameter is excepted. Instead `tolesp` - `tolpoint2d` or `tolpoint3d` is employed in contexts where tolerance of point in 2d or 3d space is excepted. - Replace tolesp with tolpoint2d/tolpoint3d in BBPP function argument. - Use tolapp3d instead tolesp in BonVoisin function,
123 lines
3.6 KiB
Plaintext
123 lines
3.6 KiB
Plaintext
puts "============"
|
|
puts "OCC22821"
|
|
puts "============"
|
|
puts ""
|
|
#########################################################################
|
|
# Crash with BRepFilletAPI_MakeFillet
|
|
#########################################################################
|
|
|
|
pload XDE
|
|
|
|
stepread [locate_data_file bug22821_test.step] t *
|
|
renamevar t_1 m
|
|
checkshape m
|
|
|
|
explode m E
|
|
|
|
if {![catch {fillet res1 m 0.01 m_1}]} {
|
|
#puts "OK: Fillet on edge m_1 was processed correctly!"
|
|
checkshape res1
|
|
checkprops res1 -s 0.220328
|
|
checkview -display res1 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
}
|
|
|
|
if {![catch {fillet res2 m 0.01 m_2}]} {
|
|
#puts "OK: Fillet on edge m_2 was processed correctly!"
|
|
checkshape res2
|
|
checkprops res2 -s 0.220328
|
|
checkview -display res2 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
}
|
|
|
|
if {![catch {fillet res3 m 0.01 m_3}]} {
|
|
#puts "OK: Fillet on edge m_3 was processed correctly!"
|
|
checkshape res3
|
|
checkprops res3 -s 0.220328
|
|
checkview -display res3 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
}
|
|
|
|
if {![catch {fillet res4 m 0.01 m_4}]} {
|
|
#puts "OK: Fillet on edge m_4 was processed correctly!"
|
|
checkshape res4
|
|
checkprops res4 -s 0.220328
|
|
checkview -display res4 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
}
|
|
|
|
if {![catch {fillet res5 m 0.01 m_5}]} {
|
|
#puts "OK: Fillet on edge m_5 was processed correctly!"
|
|
checkshape res5
|
|
checkprops res5 -s 0.218602
|
|
checkview -display res5 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
}
|
|
|
|
if {![catch {fillet res6 m 0.01 m_6}]} {
|
|
#puts "OK: Fillet on edge m_6 was processed correctly!"
|
|
checkshape res6
|
|
checkprops res6 -s 0.220328
|
|
checkview -display res6 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
}
|
|
|
|
if {![catch {fillet res7 m 0.01 m_7}]} {
|
|
#puts "OK: Fillet on edge m_7 was processed correctly!"
|
|
checkshape res7
|
|
checkprops res7 -s 0.218602
|
|
checkview -display res7 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
}
|
|
|
|
if {![catch {fillet res8 m 0.01 m_8}]} {
|
|
#puts "OK: Fillet on edge m_8 was processed correctly!"
|
|
checkshape res8
|
|
checkprops res8 -s 0.220328
|
|
checkview -display res8 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
}
|
|
|
|
if {![catch {fillet res9 m 0.01 m_9}]} {
|
|
#puts "OK: Fillet on edge m_9 was processed correctly!"
|
|
checkshape res9
|
|
checkprops res9 -s 0.218602
|
|
checkview -display res9 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
}
|
|
|
|
if {![catch {fillet res10 m 0.01 m_10}]} {
|
|
#puts "OK: Fillet on edge m_10 was processed correctly!"
|
|
checkshape res10
|
|
checkprops res10 -s 0.218602
|
|
checkview -display res10 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
}
|
|
|
|
if {![catch {fillet res11 m 0.01 m_11}]} {
|
|
#puts "OK: Fillet on edge m_11 was processed correctly!"
|
|
checkshape res11
|
|
checkprops res11 -s 0.220328
|
|
checkview -display res11 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
}
|
|
|
|
if {![catch {fillet res12 m 0.01 m_12}]} {
|
|
#puts "OK: Fillet on edge m_12 was processed correctly!"
|
|
checkshape res12
|
|
checkprops res12 -s 0.220328
|
|
checkview -display res12 -2d -path ${imagedir}/${test_image}.png
|
|
} else {
|
|
puts "Error: Crash with BRepFilletAPI_MakeFillet"
|
|
} |