test_serialize Subroutine

public subroutine test_serialize()

Arguments

None

Calls

proc~~test_serialize~~CallsGraph proc~test_serialize test_serialize assertfalse assertfalse proc~test_serialize->assertfalse asserttrue asserttrue proc~test_serialize->asserttrue none~add_attribute~3 Variable%add_attribute proc~test_serialize->none~add_attribute~3 none~add_dimension FileMetadata%add_dimension proc~test_serialize->none~add_dimension none~add_variable~2 FileMetadata%add_variable proc~test_serialize->none~add_variable~2 none~get_order FileMetadata%get_order proc~test_serialize->none~get_order none~serialize~18 FileMetadata%serialize proc~test_serialize->none~serialize~18 none~set_order FileMetadata%set_order proc~test_serialize->none~set_order proc~filemetadata_deserialize FileMetadata_deserialize proc~test_serialize->proc~filemetadata_deserialize push_back push_back proc~test_serialize->push_back

Source Code

   subroutine test_serialize()
     type (FileMetadata) :: cf1, cf2
     type (Variable) :: v1, v2
     integer,allocatable :: buffer(:)
     type (StringVector) s1, s2
     call cf1%add_dimension('x', 10)
     call cf1%add_dimension('y', 20)
     call cf1%add_dimension('z', 30) 

     v1 = Variable(type=pFIO_INT32, dimensions='x')

     v2 = Variable(type=pFIO_REAL32, dimensions='y')
     call v2%add_attribute('flag', .false.)

     call cf1%add_variable('v1',v1)
     call cf1%add_variable('v2',v2)
     call cf1%add_attribute('flag', .true.)
 
     call s1%push_back('v2')
     call s1%push_back('v1')
     call cf1%set_order(s1)

     call cf1%serialize(buffer)
     call FileMetaData_deserialize(buffer, cf2)

     s2 = cf2%get_order()

     @assertTrue(cf1 == cf2 )
     @assertTrue(s1 == s2 )

     call cf1%add_dimension('w', 10) 

     @assertFalse(cf1 == cf2 )

   end subroutine test_serialize