0030101: Application Framework - A mistake reading a RealArray attribute with too...
[occt.git] / tests / bugs / caf / bug29452
1 puts "=========="
2 puts "OCC29452"
3 puts "=========="
4 puts ""
5 ###################################################
6 # XmlMDataStd_RealDriver: Failed to read an Ocaf XML document with 1.#QNAN value
7 ###################################################
8
9 # Check for presence of warning message
10 puts "REQUIRED ALL: Cannot retrieve real member for RealArray attribute"
11
12 set BugNumber OCC29452
13 set file [locate_data_file bug29452.xml]
14
15 catch {Close D}
16 set res [Open $file D]
17
18 set real [GetReal D 0:1]
19 set rlst [GetRealList D 0:1]
20 set rarr [GetRealArray D 0:1]
21 set rarr2 [GetRealArray D 0:2]
22
23 # Check for read values
24 checkreal "Real value" [lindex $rlst 0] 1.1 0 1e-15
25 checkreal "Real value" [lindex $rlst 2] 3.3 0 1e-15
26 checkreal "Real value" [lindex $rarr 0] 0.111 0 1e-15
27 checkreal "Real value" [lindex $rarr 3] 123. 0 1e-15
28 checkreal "Real value" [lindex $rarr 4] 3.14e12 0 1e-15
29 checkreal "Real value" [lindex $rarr2 0] 2 0 1e-15
30 checkreal "Real value" [lindex $rarr2 1] 2.1219957909652723e-314 0 1e-15
31 checkreal "Real value" [lindex $rarr2 2] 5 0 1e-15
32 foreach inf [list $real [lindex $rlst 3]] {
33   if { [string compare "$inf" "inf"] && 
34        [string compare "$inf" "infinity"] && 
35        [string compare "$inf" "1.#INF"] } {
36     puts "Error: Real value is read as \"$inf\", expected infinity"
37   }
38 }
39 foreach nan [list [lindex $rlst 1] [lindex $rarr 1] [lindex $rarr 2]] {
40   if { [string compare "$nan" "nan"] && 
41        [string compare "$nan" "1.#QNAN"] } {
42     puts "Error: Real value is read as \"$nan\", expected NAN"
43   }
44 }