set aTestName "caf001-K3"
puts ${aTestName}

# Add an attribute to a data framework
set aSetX1 10
set aSetY1 20
set aSetZ1 30
set aSetDX1 100
set aSetDY1 200
set aSetDZ1 300

box aBox1 ${aSetX1} ${aSetY1} ${aSetZ1} ${aSetDX1} ${aSetDY1} ${aSetDZ1}

bounding -s aBox1 -save X1_Box1 Y1_Box1 Z1_Box1 X2_Box1 Y2_Box1 Z2_Box1

set aLabel 0:2
SetShape D ${aLabel} aBox1

# Close/Open the transaction
NewCommand D

# Save the document
set aFile $WorkDirectory/${aTestName}.${FileSuffix}

SaveToFile D $aFile

# Restore the document
Close D
Open ${aFile} DD

# Get a value of the attribute
set IsDone [catch {GetShape DD ${aLabel} aBox5} aResult]
if { ${IsDone} != 0 } {
    puts "Error : Get a value of TDataStd_Shape attribute from restoring document"
} else {
    bounding -s aBox5 -save X1_Box5 Y1_Box5 Z1_Box5 X2_Box5 Y2_Box5 Z2_Box5

if { [dval X1_Box1] != [dval X1_Box5] || 
     [dval Y1_Box1] != [dval Y1_Box5] || 
     [dval Z1_Box1] != [dval Z1_Box5] || 
     [dval X2_Box1] != [dval X2_Box5] || 
     [dval Y2_Box1] != [dval Y2_Box5] || 
     [dval Z2_Box1] != [dval Z2_Box5] } {
	puts "X1_Box1=[dval X1_Box1] X1_Box5=[dval X1_Box5]"
	puts "Y1_Box1=[dval Y1_Box1] Y1_Box5=[dval Y1_Box5]"
	puts "Z1_Box1=[dval Z1_Box1] Z1_Box5=[dval Z1_Box5]"
	puts "X2_Box1=[dval X2_Box1] X2_Box5=[dval X2_Box5]"
	puts "Y2_Box1=[dval Y2_Box1] Y2_Box5=[dval Y2_Box5]"
	puts "Z2_Box1=[dval Z2_Box1] Z2_Box5=[dval Z2_Box5]"
	puts "Error : et a value of TDataStd_Shape attribute from restoring document"
    }
}
