1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00
occt/tests/bugs/modalg_8/bug32929
Charlemagne Lasse 24e4b3c83b 0032929: Modeling Algorithms - Crash in PerformIntersectionAtEnd after deletion of surfdata
When creating a fillet, num is calculated via ChFi3d_IndexOfSurfData. If it
returns just the number of entries in surfdata, it can happen that this
value becomes invalid when handling the case "two faces common to the edge
are found". When both components are on an arc, there will be num removed
from the surfdata.

num would then be larger than the number of entries surfdata. The derived
num1 is therefore also incorrect. The subsequent usage of this
value will either:

* Debug build: cause an out of bounds exception in ChangeValue
  (`SeqFil.ChangeValue(num)`)
* Release build: cause a segfault when retrieving it via index num1
  (`SeqFil(num1)`)

num + num1 must be recalculated after the deletion happens to correctly
calculate the fillet.

Signed-off-by: Charlemagne Lasse <charlemagnelasse@gmail.com>
2022-06-03 17:51:01 +03:00

45 lines
852 B
Plaintext

puts "============"
puts "OCC32929: Modeling Algorithms - Crash in PerformIntersectionAtEnd after deletion of surfdata (fillet)"
puts "============"
puts ""
# Load & prepare data.
restore [locate_data_file bug32929.brep] b
explode b E
# Make screenshot before filleting.
smallview
donly b b_8
fit
xwd $imagedir/${test_image}_1.png
# Make fillet.
blend result b 1 b_8
# Make screenshot after filleting.
donly result
fit
xwd $imagedir/${test_image}_2.png
# Check mass.
checkprops result -s 13435.4
# Check validity of result.
checkshape result
# Check content.
set nbshapes_expected "
Number of shapes in shape
VERTEX : 25
EDGE : 40
WIRE : 17
FACE : 17
SHELL : 1
SOLID : 1
COMPSOLID : 0
COMPOUND : 1
SHAPE : 102
"
checknbshapes result -ref ${nbshapes_expected} -t -m "Result of ChFi3d_ChBuilder algorithm"