1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00
occt/tests/v3d/trsf/bug26199
kgv 0d828ac838 0032208: Tests - refactor visualization tests to cover several graphic drivers
Removed testgrids 'bugs/vis' and '3rdparty'; tests have been redistributed across other grids.
Moved testgrid 'v3d/ivtk' into dedicated 'vtk/ivtk'.

Added testgrid 'vselect' dedicated to 3D viewer picking/selection functionality
and filled with tests from 'v3d/vertex', 'v3d/face' and similar groups.

Added testgrid 'opengl' dedicated to OpenGL driver low-level functionality (GLSL programs and similar)
and filled with tests from 'v3d/glsl', 'v3d/raytrace', '3rdparty/fonts', 'bugs/vis' (portion) and similar.

Added testgrid 'opengles3' dedicated to OpenGL ES 3.0 driver low-level functionality
and reusing tests from 'opengl' testgrid.
Subgroup 'opengles3/raytrace' is disabled on Windows, as Ray-Tracing currently requires OpenGL ES 3.2.
while ANGLE library implements only OpenGL ES 3.0.

Added testgrid 'opengles2' dedicated to OpenGL ES 2.0 driver low-level functionality
and reusing a limited subset of passing tests from 'opengl' testgrid.
Currently testgrid is activated only on Windows platform when using ANGLE library
(properietary OpenGL ES drivers do not allow creation of restricted 2.0 context).

Test cases have been cleaned out to put bug description into log,
to properly load necessary plugins and to explicitly dump viewer.
2021-03-25 19:14:33 +03:00

70 lines
1.8 KiB
Plaintext

puts "=========="
puts "OCC26199: Visualization - use NCollection_IndexedMap instead of NCollection_Sequence in OpenGl_BVHClipPrimitiveSet to improve performance"
puts "=========="
puts ""
pload MODELING VISUALIZATION
psphere s 0.5
tclean s
incmesh s 0.1
trinfo s
vinit View1
vclear
vaxo
vsetdispmode 1
vdefaults -defl 1.0 -autoTriang off
# Warning, unknown argument '-DEFL'
vdisplay s
set aNb1 100
# display 100x100 connected instances of single presentation
puts "Creating [expr $aNb1*$aNb1] instances..."
set t1 [time {for {set i 0} {$i < $aNb1} {incr i} {for {set j 0} {$j < $aNb1} {incr j} {vconnectto s_${i}_${j} ${i} ${j} 0 s -noupdate}}}]
# the following command is slow
set t2 [time {vclear}]
set d1 [lindex $t1 0]
puts "vconnectto done in $d1 microseconds!\n"
set d2 [lindex $t2 0]
puts "vclear done in $d2 microseconds!\n"
set t1_sec [expr $d1 * 1.e-6]
set t2_sec [expr $d2 * 1.e-6]
if { [regexp {Debug mode} [dversion]] } {
if { [regexp {Windows} [dversion]] } {
set max_time_vconnectto 5
set max_time_vclear 5
} else {
set max_time_vconnectto 5
set max_time_vclear 5
}
} else {
if { [regexp {Windows} [dversion]] } {
set max_time_vconnectto 1
set max_time_vclear 1
} else {
set max_time_vconnectto 1
set max_time_vclear 1
}
}
if { ${t1_sec} > ${max_time_vconnectto} } {
puts "Elapsed time of vconnectto is more than ${max_time_vconnectto} seconds - Error"
} else {
puts "Elapsed time of vconnectto is less than ${max_time_vconnectto} seconds - OK"
}
if { ${t2_sec} > ${max_time_vclear} } {
puts "Elapsed time of vclear is more than ${max_time_vclear} seconds - Error"
} else {
puts "Elapsed time of vclear is less than ${max_time_vclear} seconds - OK"
}