mirror of
https://github.com/HDFGroup/hdf5.git
synced 2024-12-09 07:32:32 +08:00
89fbe00dec
* commit '54957d37f5aa73912763dbb6e308555e863c43f4': Commit copyright header change for src/H5PLpkg.c which was added after running script to make changes. Add new files in release_docs to MANIFEST. Cimmit changes to Makefile.in(s) and H5PL.c that resulted from running autogen.sh. Merge pull request #407 in HDFFV/hdf5 from ~LRKNOX/hdf5_lrk:hdf5_1_10_1 to hdf5_1_10_1 Change copyright headers to replace url referring to file to be removed and replace it with new url for COPYING file.
1012 lines
38 KiB
Java
1012 lines
38 KiB
Java
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
* Copyright by The HDF Group. *
|
|
* Copyright by the Board of Trustees of the University of Illinois. *
|
|
* All rights reserved. *
|
|
* *
|
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
* terms governing use, modification, and redistribution, is contained in *
|
|
* the COPYING file, which can be found at the root of the source code *
|
|
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
|
* If you do not have access to either file, you may request a copy from *
|
|
* help@hdfgroup.org. *
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
package test;
|
|
|
|
import static org.junit.Assert.assertEquals;
|
|
import static org.junit.Assert.assertFalse;
|
|
import static org.junit.Assert.assertTrue;
|
|
import static org.junit.Assert.fail;
|
|
|
|
import java.util.ArrayList;
|
|
import java.io.File;
|
|
import java.text.DecimalFormat;
|
|
import java.text.NumberFormat;
|
|
import java.nio.charset.StandardCharsets;
|
|
|
|
import hdf.hdf5lib.H5;
|
|
import hdf.hdf5lib.HDF5Constants;
|
|
import hdf.hdf5lib.HDFNativeData;
|
|
import hdf.hdf5lib.callbacks.H5P_cls_close_func_cb;
|
|
import hdf.hdf5lib.callbacks.H5P_cls_close_func_t;
|
|
import hdf.hdf5lib.callbacks.H5P_cls_copy_func_cb;
|
|
import hdf.hdf5lib.callbacks.H5P_cls_copy_func_t;
|
|
import hdf.hdf5lib.callbacks.H5P_cls_create_func_cb;
|
|
import hdf.hdf5lib.callbacks.H5P_cls_create_func_t;
|
|
import hdf.hdf5lib.callbacks.H5P_prp_set_func_cb;
|
|
import hdf.hdf5lib.callbacks.H5P_prp_get_func_cb;
|
|
import hdf.hdf5lib.callbacks.H5P_prp_delete_func_cb;
|
|
import hdf.hdf5lib.callbacks.H5P_prp_copy_func_cb;
|
|
import hdf.hdf5lib.callbacks.H5P_prp_compare_func_cb;
|
|
import hdf.hdf5lib.callbacks.H5P_prp_close_func_cb;
|
|
import hdf.hdf5lib.callbacks.H5P_prp_create_func_cb;
|
|
import hdf.hdf5lib.callbacks.H5P_iterate_cb;
|
|
import hdf.hdf5lib.callbacks.H5P_iterate_t;
|
|
import hdf.hdf5lib.exceptions.HDF5Exception;
|
|
import hdf.hdf5lib.exceptions.HDF5LibraryException;
|
|
import hdf.hdf5lib.structs.H5AC_cache_config_t;
|
|
|
|
import org.junit.After;
|
|
import org.junit.Before;
|
|
import org.junit.Rule;
|
|
import org.junit.Test;
|
|
import org.junit.rules.TestName;
|
|
|
|
public class TestH5Plist {
|
|
@Rule public TestName testname = new TestName();
|
|
|
|
// Property definitions
|
|
private static final String CLASS1_NAME = "Class 1";
|
|
private static final String CLASS1_PATH = "root/Class 1";
|
|
|
|
private static final String CLASS2_NAME = "Class 2";
|
|
private static final String CLASS2_PATH = "root/Class 1/Class 2";
|
|
|
|
// Property definitions
|
|
private static final String PROP1_NAME = "Property 1";
|
|
private static final int prop1_def = 10; // Property 1 default value
|
|
private static final int PROP1_SIZE = 2;
|
|
|
|
private static final String PROP2_NAME = "Property 2";
|
|
private static final float prop2_def = 3.14F; // Property 2 default value
|
|
private static final int PROP2_SIZE = 8;
|
|
|
|
private static final String PROP3_NAME = "Property 3";
|
|
private static final char[] prop3_def = {'T','e','n',' ','c','h','a','r','s',' '}; // Property 3 default value
|
|
private static final int PROP3_SIZE = 10;
|
|
|
|
private static final String PROP4_NAME = "Property 4";
|
|
private static final double prop4_def = 1.41F; // Property 4 default value
|
|
private static final int PROP4_SIZE = 8;
|
|
|
|
private static final String [] pnames = { // Names of properties for iterator
|
|
PROP1_NAME,
|
|
PROP2_NAME,
|
|
PROP3_NAME,
|
|
PROP4_NAME};
|
|
|
|
long plist_class_id = -1;
|
|
|
|
@Before
|
|
public void createPropClass()throws NullPointerException, HDF5Exception
|
|
{
|
|
assertTrue("H5 open ids is 0",H5.getOpenIDCount()==0);
|
|
System.out.print(testname.getMethodName());
|
|
// Create a new generic class, derived from the root of the class hierarchy
|
|
try {
|
|
plist_class_id = H5.H5Pcreate_class_nocb(HDF5Constants.H5P_ROOT, CLASS1_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("TestH5Plist.H5Pcreate_class: " + err);
|
|
}
|
|
assertTrue(plist_class_id > 0);
|
|
}
|
|
|
|
@After
|
|
public void deleteFileAccess() throws HDF5LibraryException {
|
|
if (plist_class_id > 0)
|
|
try {H5.H5Pclose(plist_class_id);} catch (Exception ex) {}
|
|
System.out.println();
|
|
}
|
|
|
|
// Test basic generic property list code. Tests creating new generic classes.
|
|
@Test
|
|
public void testH5P_genprop_basic_class() {
|
|
int status = -1;
|
|
long cid1 = -1; // Generic Property class ID
|
|
long cid2 = -1; // Generic Property class ID
|
|
long cid3 = -1; // Generic Property class ID
|
|
String name = null; // Name of class
|
|
|
|
try {
|
|
// Check class name
|
|
try {
|
|
name = H5.H5Pget_class_name(plist_class_id);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_class_name plist_class_id: " + err);
|
|
}
|
|
assertTrue("Class names don't match!, "+name+"="+CLASS1_NAME+"\n", name.compareTo(CLASS1_NAME)==0);
|
|
|
|
// Check class parent
|
|
try {
|
|
cid2 = H5.H5Pget_class_parent(plist_class_id);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_class_parent cid2: " + err);
|
|
}
|
|
|
|
// Verify class parent correct
|
|
try {
|
|
status = H5.H5Pequal(cid2, HDF5Constants.H5P_ROOT);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pequal cid2: " + err);
|
|
}
|
|
assertTrue("H5Pequal cid2", status >= 0);
|
|
|
|
// Make certain false postives aren't being returned
|
|
try {
|
|
status = H5.H5Pequal(cid2, HDF5Constants.H5P_FILE_CREATE);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pequal cid2: " + err);
|
|
}
|
|
assertTrue("H5Pequal cid2", status >= 0);
|
|
|
|
// Close parent class
|
|
try {
|
|
H5.H5Pclose_class(cid2);
|
|
cid2 = -1;
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pclose_class cid2: " + err);
|
|
}
|
|
|
|
// Close class
|
|
try {
|
|
H5.H5Pclose_class(plist_class_id);
|
|
plist_class_id = -1;
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pclose_class plist_class_id: " + err);
|
|
}
|
|
|
|
// Create another new generic class, derived from file creation class
|
|
try {
|
|
cid1 = H5.H5Pcreate_class_nocb(HDF5Constants.H5P_FILE_CREATE, CLASS2_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pcreate_class cid1: " + err);
|
|
}
|
|
assertTrue("H5Pcreate_class cid1", cid1 >= 0);
|
|
|
|
// Check class name
|
|
try {
|
|
name = H5.H5Pget_class_name(cid1);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_class_name cid1: " + err);
|
|
}
|
|
assertTrue("Class names don't match!, "+name+"="+CLASS2_NAME+"\n", name.compareTo(CLASS2_NAME)==0);
|
|
|
|
// Check class parent
|
|
try {
|
|
cid2 = H5.H5Pget_class_parent(cid1);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_class_parent cid2: " + err);
|
|
}
|
|
assertTrue("H5Pget_class_parent cid2 ", cid2 >= 0);
|
|
|
|
// Verify class parent correct
|
|
try {
|
|
status = H5.H5Pequal(cid2, HDF5Constants.H5P_FILE_CREATE);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pequal cid2: " + err);
|
|
}
|
|
assertTrue("H5Pequal cid2 ", status >= 0);
|
|
|
|
// Check class parent's parent
|
|
try {
|
|
cid3 = H5.H5Pget_class_parent(cid2);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_class_parent cid3: " + err);
|
|
}
|
|
assertTrue("H5Pget_class_parent cid3", cid3 >= 0);
|
|
|
|
// Verify class parent's parent correct
|
|
try {
|
|
status = H5.H5Pequal(cid3, HDF5Constants.H5P_GROUP_CREATE);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pequal cid3: " + err);
|
|
}
|
|
assertTrue("H5Pequal cid3 ", status >= 0);
|
|
|
|
// Close parent class's parent
|
|
try {
|
|
H5.H5Pclose_class(cid3);
|
|
cid3 = -1;
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pclose_class cid3: " + err);
|
|
}
|
|
|
|
// Close parent class's parent
|
|
try {
|
|
H5.H5Pclose_class(cid2);
|
|
cid2 = -1;
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pclose_class cid2: " + err);
|
|
}
|
|
|
|
// Close parent class's parent
|
|
try {
|
|
H5.H5Pclose_class(cid1);
|
|
cid1 = -1;
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pclose_class cid1: " + err);
|
|
}
|
|
}
|
|
finally {
|
|
if (cid3 > 0)
|
|
try {H5.H5Pclose_class(cid3);} catch (Throwable err) {}
|
|
if (cid2 > 0)
|
|
try {H5.H5Pclose_class(cid2);} catch (Throwable err) {}
|
|
if (cid1 > 0)
|
|
try {H5.H5Pclose_class(cid1);} catch (Throwable err) {}
|
|
}
|
|
}
|
|
|
|
// Test basic generic property list code. Tests adding properties to generic classes.
|
|
@Test
|
|
public void testH5P_genprop_basic_class_prop() {
|
|
boolean status = false;
|
|
long size = -1; // Generic Property size
|
|
long nprops = -1; // Generic Property class number
|
|
|
|
// Check the number of properties in class
|
|
try {
|
|
nprops = H5.H5Pget_nprops(plist_class_id);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_nprops plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pget_nprops: "+nprops, nprops==0);
|
|
|
|
// Check the existance of the first property (should fail)
|
|
try {
|
|
status = H5.H5Pexist(plist_class_id, PROP1_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pexist plist_class_id: " + err);
|
|
}
|
|
assertFalse("H5Pexist plist_class_id "+PROP1_NAME, status);
|
|
|
|
// Insert first property into class (with no callbacks)
|
|
try {
|
|
byte[] prop_value = HDFNativeData.intToByte(prop1_def);
|
|
|
|
H5.H5Pregister2_nocb(plist_class_id, PROP1_NAME, PROP1_SIZE, prop_value);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pregister2 plist_class_id: "+PROP1_NAME + err);
|
|
}
|
|
|
|
// Try to insert the first property again (should fail)
|
|
try {
|
|
byte[] prop_value = HDFNativeData.intToByte(prop1_def);
|
|
|
|
H5.H5Pregister2_nocb(plist_class_id, PROP1_NAME, PROP1_SIZE, prop_value);
|
|
fail("H5Pregister2 plist_class_id: "+PROP1_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
}
|
|
|
|
// Check the existance of the first property
|
|
try {
|
|
status = H5.H5Pexist(plist_class_id, PROP1_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pexist plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pexist plist_class_id "+PROP1_NAME, status);
|
|
|
|
// Check the size of the first property
|
|
try {
|
|
size = H5.H5Pget_size(plist_class_id, PROP1_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_size PROP1_NAME: " + err);
|
|
}
|
|
assertTrue("H5Pget_size "+PROP1_NAME +" size: "+size, size == PROP1_SIZE);
|
|
|
|
// Check the number of properties in class
|
|
try {
|
|
nprops = H5.H5Pget_nprops(plist_class_id);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_nprops plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pget_nprops: "+nprops, nprops==1);
|
|
|
|
// Insert second property into class (with no callbacks)
|
|
try {
|
|
byte[] prop_value = HDFNativeData.floatToByte(prop2_def);
|
|
|
|
H5.H5Pregister2_nocb(plist_class_id, PROP2_NAME, PROP2_SIZE, prop_value);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pregister2 plist_class_id: "+PROP2_NAME + err);
|
|
}
|
|
|
|
// Try to insert the second property again (should fail)
|
|
try {
|
|
byte[] prop_value = HDFNativeData.floatToByte(prop2_def);
|
|
|
|
H5.H5Pregister2_nocb(plist_class_id, PROP2_NAME, PROP2_SIZE, prop_value);
|
|
fail("H5Pregister2 plist_class_id: "+PROP2_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
}
|
|
|
|
// Check the existance of the second property
|
|
try {
|
|
status = H5.H5Pexist(plist_class_id, PROP2_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pexist plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pexist plist_class_id "+PROP2_NAME, status);
|
|
|
|
// Check the size of the second property
|
|
try {
|
|
size = H5.H5Pget_size(plist_class_id, PROP2_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_size PROP2_NAME: " + err);
|
|
}
|
|
assertTrue("H5Pget_size "+PROP2_NAME +" size: "+size, size == PROP2_SIZE);
|
|
|
|
// Check the number of properties in class
|
|
try {
|
|
nprops = H5.H5Pget_nprops(plist_class_id);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_nprops plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pget_nprops: "+nprops, nprops==2);
|
|
|
|
// Insert third property into class (with no callbacks)
|
|
try {
|
|
byte[] prop_value = new String(prop3_def).getBytes(StandardCharsets.UTF_8);
|
|
|
|
H5.H5Pregister2_nocb(plist_class_id, PROP3_NAME, PROP3_SIZE, prop_value);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pregister2 plist_class_id: "+PROP3_NAME + err);
|
|
}
|
|
|
|
// Check the existance of the third property
|
|
try {
|
|
status = H5.H5Pexist(plist_class_id, PROP3_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pexist plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pexist plist_class_id "+PROP3_NAME, status);
|
|
|
|
// Check the size of the third property
|
|
try {
|
|
size = H5.H5Pget_size(plist_class_id, PROP3_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_size PROP3_NAME: " + err);
|
|
}
|
|
assertTrue("H5Pget_size "+PROP3_NAME +" size: "+size, size == PROP3_SIZE);
|
|
|
|
// Check the number of properties in class
|
|
try {
|
|
nprops = H5.H5Pget_nprops(plist_class_id);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_nprops plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pget_nprops: "+nprops, nprops==3);
|
|
|
|
// Unregister first property
|
|
try {
|
|
H5.H5Punregister(plist_class_id, PROP1_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Punregister plist_class_id: "+PROP1_NAME + err);
|
|
}
|
|
|
|
// Try to check the size of the first property (should fail)
|
|
try {
|
|
size = H5.H5Pget_size(plist_class_id, PROP1_NAME);
|
|
fail("H5Pget_size PROP1_NAME");
|
|
}
|
|
catch (Throwable err) {
|
|
}
|
|
|
|
// Check the number of properties in class
|
|
try {
|
|
nprops = H5.H5Pget_nprops(plist_class_id);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_nprops plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pget_nprops: "+nprops, nprops==2);
|
|
|
|
// Unregister second property
|
|
try {
|
|
H5.H5Punregister(plist_class_id, PROP2_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Punregister plist_class_id: "+PROP2_NAME + err);
|
|
}
|
|
|
|
// Check the number of properties in class
|
|
try {
|
|
nprops = H5.H5Pget_nprops(plist_class_id);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_nprops plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pget_nprops: "+nprops, nprops==1);
|
|
|
|
// Unregister third property
|
|
try {
|
|
H5.H5Punregister(plist_class_id, PROP3_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Punregister plist_class_id: "+PROP3_NAME + err);
|
|
}
|
|
|
|
// Check the number of properties in class
|
|
try {
|
|
nprops = H5.H5Pget_nprops(plist_class_id);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_nprops plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pget_nprops: "+nprops, nprops==0);
|
|
}
|
|
|
|
// Test basic generic property list code. Tests iterating over properties in a generic class.
|
|
@Test
|
|
public void testH5P_genprop_class_iter() {
|
|
class idata {
|
|
public String[] iter_names= null;
|
|
public int iter_count = -1;
|
|
idata(String[] names, int count) {
|
|
this.iter_names = names;
|
|
this.iter_count = count;
|
|
}
|
|
}
|
|
class H5P_iter_data implements H5P_iterate_t {
|
|
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
|
}
|
|
H5P_iterate_t iter_data = new H5P_iter_data();
|
|
|
|
class H5P_iter_callback implements H5P_iterate_cb {
|
|
public int callback(long list_id, String name, H5P_iterate_t op_data) {
|
|
idata id = ((H5P_iter_data)op_data).iterdata.get(0);
|
|
return name.compareTo(id.iter_names[id.iter_count++]);
|
|
}
|
|
}
|
|
H5P_iterate_cb iter_cb = new H5P_iter_callback();
|
|
|
|
long size = -1; // Generic Property size
|
|
long nprops = -1; // Generic Property class number
|
|
int[] idx = {0}; // Index to start iteration at
|
|
|
|
// Insert first property into class (with no callbacks) */
|
|
try {
|
|
byte[] prop_value = HDFNativeData.intToByte(prop1_def);
|
|
|
|
H5.H5Pregister2_nocb(plist_class_id, PROP1_NAME, PROP1_SIZE, prop_value);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pregister2 plist_class_id: "+PROP1_NAME + err);
|
|
}
|
|
|
|
// Insert second property into class (with no callbacks) */
|
|
try {
|
|
byte[] prop_value = HDFNativeData.floatToByte(prop2_def);
|
|
|
|
H5.H5Pregister2_nocb(plist_class_id, PROP2_NAME, PROP2_SIZE, prop_value);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pregister2 plist_class_id: "+PROP2_NAME + err);
|
|
}
|
|
|
|
// Insert third property into class (with no callbacks) */
|
|
try {
|
|
byte[] prop_value = new String(prop3_def).getBytes(StandardCharsets.UTF_8);
|
|
|
|
H5.H5Pregister2_nocb(plist_class_id, PROP3_NAME, PROP3_SIZE, prop_value);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pregister2 plist_class_id: "+PROP3_NAME + err);
|
|
}
|
|
|
|
// Insert fourth property into class (with no callbacks) */
|
|
try {
|
|
byte[] prop_value = HDFNativeData.doubleToByte(prop4_def);
|
|
|
|
H5.H5Pregister2_nocb(plist_class_id, PROP4_NAME, PROP4_SIZE, prop_value);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pregister2 plist_class_id: "+PROP4_NAME + err);
|
|
}
|
|
|
|
// Check the number of properties in class */
|
|
try {
|
|
nprops = H5.H5Pget_nprops(plist_class_id);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_nprops plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pget_nprops: "+nprops, nprops==4);
|
|
|
|
// Iterate over all properties in class */
|
|
idata id = new idata(pnames, 0);
|
|
((H5P_iter_data)iter_data).iterdata.add(id);
|
|
try {
|
|
H5.H5Piterate(plist_class_id, null, iter_cb, iter_data);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5.H5Piterate: " + err);
|
|
}
|
|
assertFalse("H5Piterate ",((H5P_iter_data)iter_data).iterdata.isEmpty());
|
|
assertTrue("H5Piterate "+((H5P_iter_data)iter_data).iterdata.size(),((H5P_iter_data)iter_data).iterdata.size()==1);
|
|
assertTrue("H5Piterate "+(((H5P_iter_data)iter_data).iterdata.get(0)).iter_count,((idata)((H5P_iter_data)iter_data).iterdata.get(0)).iter_count==4);
|
|
|
|
// Iterate over last three properties in class */
|
|
idx[0] = 1;
|
|
((H5P_iter_data)iter_data).iterdata.get(0).iter_count = 1;
|
|
try {
|
|
H5.H5Piterate(plist_class_id, idx, iter_cb, iter_data);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5.H5Piterate: " + err);
|
|
}
|
|
assertFalse("H5Piterate ",((H5P_iter_data)iter_data).iterdata.isEmpty());
|
|
assertTrue("H5Piterate "+((H5P_iter_data)iter_data).iterdata.size(),((H5P_iter_data)iter_data).iterdata.size()==1);
|
|
assertTrue("H5Piterate "+(((H5P_iter_data)iter_data).iterdata.get(0)).iter_count,((idata)((H5P_iter_data)iter_data).iterdata.get(0)).iter_count==4);
|
|
|
|
assertTrue("H5Piterate: "+nprops+"="+idx[0], nprops == idx[0]);
|
|
}
|
|
|
|
// Test basic generic property list code.
|
|
// Tests creating new generic property lists and adding and
|
|
// removing properties from them.
|
|
@Test
|
|
public void testH5P_genprop_basic_list_prop() {
|
|
boolean status = false;
|
|
long lid1 = -1; // Generic Property list ID
|
|
long nprops = -1; // Number of properties in class
|
|
|
|
try {
|
|
// Add several properties (several w/default values)
|
|
|
|
// Insert first property into class (with no callbacks)
|
|
try {
|
|
byte[] prop_value = HDFNativeData.intToByte(prop1_def);
|
|
|
|
H5.H5Pregister2_nocb(plist_class_id, PROP1_NAME, PROP1_SIZE, prop_value);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pregister2 plist_class_id: "+PROP1_NAME + err);
|
|
}
|
|
|
|
// Insert second property into class (with no callbacks)
|
|
try {
|
|
byte[] prop_value = HDFNativeData.floatToByte(prop2_def);
|
|
|
|
H5.H5Pregister2_nocb(plist_class_id, PROP2_NAME, PROP2_SIZE, prop_value);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pregister2 plist_class_id: "+PROP2_NAME + err);
|
|
}
|
|
|
|
// Create a property list from the class
|
|
try {
|
|
lid1 = H5.H5Pcreate(plist_class_id);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pcreate lid1: " + err);
|
|
}
|
|
|
|
// Check the number of properties in class
|
|
try {
|
|
nprops = H5.H5Pget_nprops(lid1);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_nprops lid1: " + err);
|
|
}
|
|
assertTrue("H5Pget_nprops: "+nprops, nprops==2);
|
|
|
|
// Add temporary properties
|
|
|
|
// Insert first temporary property into list (with no callbacks)
|
|
try {
|
|
byte[] prop_value = new String(prop3_def).getBytes(StandardCharsets.UTF_8);
|
|
|
|
H5.H5Pinsert2_nocb(lid1, PROP3_NAME, PROP3_SIZE, prop_value);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pinsertr2 lid1: "+PROP3_NAME + err);
|
|
}
|
|
|
|
// Insert second temporary property into list (with no callbacks)
|
|
try {
|
|
byte[] prop_value = HDFNativeData.doubleToByte(prop4_def);
|
|
|
|
H5.H5Pinsert2_nocb(lid1, PROP4_NAME, PROP4_SIZE, prop_value);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pinsert2 lid1: "+PROP4_NAME + err);
|
|
}
|
|
|
|
// Check the number of properties in class
|
|
try {
|
|
nprops = H5.H5Pget_nprops(lid1);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pget_nprops lid1: " + err);
|
|
}
|
|
assertTrue("H5Pget_nprops: "+nprops, nprops==4);
|
|
|
|
// Check existence of all properties
|
|
try {
|
|
status = H5.H5Pexist(lid1, PROP1_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pexist plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pexist lid1 "+PROP1_NAME, status);
|
|
try {
|
|
status = H5.H5Pexist(lid1, PROP2_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pexist plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pexist lid1 "+PROP2_NAME, status);
|
|
try {
|
|
status = H5.H5Pexist(lid1, PROP3_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pexist plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pexist lid1 "+PROP3_NAME, status);
|
|
try {
|
|
status = H5.H5Pexist(lid1, PROP4_NAME);
|
|
}
|
|
catch (Throwable err) {
|
|
err.printStackTrace();
|
|
fail("H5Pexist plist_class_id: " + err);
|
|
}
|
|
assertTrue("H5Pexist lid1 "+PROP4_NAME, status);
|
|
|
|
}
|
|
finally {
|
|
if (lid1 > 0)
|
|
try {H5.H5Pclose(lid1);} catch (Throwable err) {}
|
|
}
|
|
}
|
|
|
|
// // Test basic generic property list code. Tests callbacks for property lists in a generic class.
|
|
// @Test
|
|
// public void testH5P_genprop_class_callback() {
|
|
// class cdata {
|
|
// public long cls_id = -1;
|
|
// public int cls_count = -1;
|
|
// cdata(long id, int count) {
|
|
// this.cls_id = id;
|
|
// this.cls_count = count;
|
|
// }
|
|
// }
|
|
// class H5P_cls_create_data implements H5P_cls_create_func_t {
|
|
// public ArrayList<cdata> clsdata = new ArrayList<cdata>();
|
|
// }
|
|
// H5P_cls_create_func_t cls_create_data = new H5P_cls_create_data();
|
|
//
|
|
// class H5P_cls_create_callback implements H5P_cls_create_func_cb {
|
|
// public int callback(long list_id, H5P_cls_create_func_t cls_data) {
|
|
// System.err.println("H5P_cls_create_callback enter");
|
|
// cdata cd = ((H5P_cls_create_data)cls_create_data).clsdata.get(0);
|
|
// cd.cls_count++;
|
|
// cd.cls_id = list_id;
|
|
// return 0;
|
|
// }
|
|
// }
|
|
// H5P_cls_create_func_cb cls_create_cb = new H5P_cls_create_callback();
|
|
//
|
|
// class H5P_cls_copy_data implements H5P_cls_copy_func_t {
|
|
// public ArrayList<cdata> clsdata = new ArrayList<cdata>();
|
|
// }
|
|
// H5P_cls_copy_func_t cls_copy_data = new H5P_cls_copy_data();
|
|
//
|
|
// class H5P_cls_copy_callback implements H5P_cls_copy_func_cb {
|
|
// public int callback(long list_id1, long list_id2, H5P_cls_copy_func_t cls_data) {
|
|
// cdata cd = ((H5P_cls_copy_data)cls_copy_data).clsdata.get(0);
|
|
// cd.cls_count++;
|
|
// cd.cls_id = list_id1;
|
|
// return 0;
|
|
// }
|
|
// }
|
|
// H5P_cls_copy_func_cb cls_copy_cb = new H5P_cls_copy_callback();
|
|
//
|
|
// class H5P_cls_close_data implements H5P_cls_close_func_t {
|
|
// public ArrayList<cdata> clsdata = new ArrayList<cdata>();
|
|
// }
|
|
// H5P_cls_close_func_t cls_close_data = new H5P_cls_close_data();
|
|
//
|
|
// class H5P_cls_close_callback implements H5P_cls_close_func_cb {
|
|
// public int callback(long list_id, H5P_cls_close_func_t cls_data) {
|
|
// cdata cd = ((H5P_cls_close_data)cls_close_data).clsdata.get(0);
|
|
// cd.cls_count++;
|
|
// cd.cls_id = list_id;
|
|
// return 0;
|
|
// }
|
|
// }
|
|
// H5P_cls_close_func_cb cls_close_cb = new H5P_cls_close_callback();
|
|
//
|
|
// long cid1 = -1; // Generic Property class ID
|
|
// long cid2 = -1; // Generic Property class ID
|
|
// long lid1 = -1; // Generic Property list ID
|
|
// long lid2 = -1; // Generic Property list ID
|
|
// long lid3 = -1; // Generic Property list ID
|
|
// long nprops = -1; // Number of properties in class
|
|
//
|
|
// try {
|
|
// // Create a new generic class, derived from the root of the class hierarchy
|
|
// try {
|
|
// cid1 = H5.H5Pcreate_class(HDF5Constants.H5P_ROOT, CLASS1_NAME, cls_create_cb, cls_create_data, cls_copy_cb, cls_copy_data, cls_close_cb, cls_close_data);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pcreate_class cid1: " + err);
|
|
// }
|
|
// assertTrue("H5Pcreate_class cid1", cid1 >= 0);
|
|
//
|
|
// // Insert first property into class (with no callbacks)
|
|
// try {
|
|
// byte[] prop_value = HDFNativeData.intToByte(prop1_def);
|
|
//
|
|
// H5.H5Pregister2(cid1, PROP1_NAME, PROP1_SIZE, prop_value, null, null, null, null, null, null, null);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pregister2 cid1: "+PROP1_NAME + err);
|
|
// }
|
|
//
|
|
// // Insert second property into class (with no callbacks)
|
|
// try {
|
|
// byte[] prop_value = HDFNativeData.floatToByte(prop2_def);
|
|
//
|
|
// H5.H5Pregister2(cid1, PROP2_NAME, PROP2_SIZE, prop_value, null, null, null, null, null, null, null);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pregister2 cid1: "+PROP2_NAME + err);
|
|
// }
|
|
//
|
|
// // Insert third property into class (with no callbacks)
|
|
// try {
|
|
// byte[] prop_value = new String(prop3_def).getBytes(StandardCharsets.UTF_8);
|
|
//
|
|
// H5.H5Pregister2(cid1, PROP3_NAME, PROP3_SIZE, prop_value, null, null, null, null, null, null, null);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pregister2 cid1: "+PROP3_NAME + err);
|
|
// }
|
|
//
|
|
// // Check the number of properties in class
|
|
// try {
|
|
// nprops = H5.H5Pget_nprops(cid1);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pget_nprops cid1: " + err);
|
|
// }
|
|
// assertTrue("H5Pget_nprops: "+nprops, nprops==3);
|
|
//
|
|
// // Initialize class callback structs
|
|
// cdata create_id = new cdata(-1, 0);
|
|
// cdata copy_id = new cdata(-1, 0);
|
|
// cdata close_id = new cdata(-1, 0);
|
|
// ((H5P_cls_create_data)cls_create_data).clsdata.add(create_id);
|
|
// ((H5P_cls_copy_data)cls_copy_data).clsdata.add(copy_id);
|
|
// ((H5P_cls_close_data)cls_close_data).clsdata.add(close_id);
|
|
//
|
|
// // Create a property list from the class
|
|
// try {
|
|
// lid1 = H5.H5Pcreate(cid1);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pcreate lid1: " + err);
|
|
// }
|
|
//
|
|
// // Verify that the creation callback occurred
|
|
// assertFalse("H5Pcreate ",((H5P_cls_create_data)cls_create_data).clsdata.isEmpty());
|
|
// assertTrue("H5Pcreate "+((H5P_cls_create_data)cls_create_data).clsdata.get(0).cls_id ,((H5P_cls_create_data)cls_create_data).clsdata.get(0).cls_id == lid1);
|
|
// assertTrue("H5Pcreate "+(((H5P_cls_create_data)cls_create_data).clsdata.get(0)).cls_count,((cdata)((H5P_cls_create_data)cls_create_data).clsdata.get(0)).cls_count==1);
|
|
//
|
|
// // Check the number of properties in list
|
|
// try {
|
|
// nprops = H5.H5Pget_nprops(lid1);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pget_nprops lid1: " + err);
|
|
// }
|
|
// assertTrue("H5Pget_nprops: "+nprops, nprops==3);
|
|
//
|
|
// // Create another property list from the class
|
|
// try {
|
|
// lid2 = H5.H5Pcreate(cid1);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pcreate lid2: " + err);
|
|
// }
|
|
//
|
|
// /* Verify that the creation callback occurred */
|
|
// assertFalse("H5Pcreate ",((H5P_cls_create_data)cls_create_data).clsdata.isEmpty());
|
|
// assertTrue("H5Pcreate "+((H5P_cls_create_data)cls_create_data).clsdata.get(0).cls_id ,((H5P_cls_create_data)cls_create_data).clsdata.get(0).cls_id == lid2);
|
|
// assertTrue("H5Pcreate "+(((H5P_cls_create_data)cls_create_data).clsdata.get(0)).cls_count,((cdata)((H5P_cls_create_data)cls_create_data).clsdata.get(0)).cls_count==2);
|
|
//
|
|
// // Check the number of properties in list
|
|
// try {
|
|
// nprops = H5.H5Pget_nprops(lid2);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pget_nprops lid2: " + err);
|
|
// }
|
|
// assertTrue("H5Pget_nprops: "+nprops, nprops==3);
|
|
//
|
|
// // Create another property list by copying an existing list
|
|
// try {
|
|
// lid3= H5.H5Pcopy(lid1);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pcopy lid3: " + err);
|
|
// }
|
|
//
|
|
// // Verify that the copy callback occurred
|
|
// assertFalse("H5Pcopy ",((H5P_cls_copy_data)cls_copy_data).clsdata.isEmpty());
|
|
// assertTrue("H5Pcopy "+((H5P_cls_copy_data)cls_copy_data).clsdata.get(0).cls_id ,((H5P_cls_copy_data)cls_copy_data).clsdata.get(0).cls_id == lid3);
|
|
// assertTrue("H5Pcopy "+(((H5P_cls_copy_data)cls_copy_data).clsdata.get(0)).cls_count,((cdata)((H5P_cls_copy_data)cls_copy_data).clsdata.get(0)).cls_count==1);
|
|
//
|
|
// // Check the number of properties in list
|
|
// try {
|
|
// nprops = H5.H5Pget_nprops(lid3);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pget_nprops lid3: " + err);
|
|
// }
|
|
// assertTrue("H5Pget_nprops: "+nprops, nprops==3);
|
|
//
|
|
// // Close first list
|
|
// try {
|
|
// H5.H5Pclose(lid1);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pclose lid1: " + err);
|
|
// }
|
|
//
|
|
// /* Verify that the close callback occurred */
|
|
// assertFalse("H5Pclose ",((H5P_cls_close_data)cls_close_data).clsdata.isEmpty());
|
|
// assertTrue("H5Pclose "+((H5P_cls_close_data)cls_close_data).clsdata.get(0).cls_id ,((H5P_cls_close_data)cls_copy_data).clsdata.get(0).cls_id == lid1);
|
|
// assertTrue("H5Pclose "+(((H5P_cls_close_data)cls_close_data).clsdata.get(0)).cls_count,((cdata)((H5P_cls_close_data)cls_copy_data).clsdata.get(0)).cls_count==1);
|
|
//
|
|
// // Close second list
|
|
// try {
|
|
// H5.H5Pclose(lid2);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pclose lid2: " + err);
|
|
// }
|
|
//
|
|
// // Verify that the close callback occurred
|
|
// assertTrue("H5Pclose "+((H5P_cls_close_data)cls_close_data).clsdata.get(0).cls_id ,((H5P_cls_close_data)cls_close_data).clsdata.get(0).cls_id == lid2);
|
|
// assertTrue("H5Pclose "+(((H5P_cls_close_data)cls_close_data).clsdata.get(0)).cls_count,((cdata)((H5P_cls_close_data)cls_close_data).clsdata.get(0)).cls_count==2);
|
|
//
|
|
// // Close third list
|
|
// try {
|
|
// H5.H5Pclose(lid3);
|
|
// }
|
|
// catch (Throwable err) {
|
|
// err.printStackTrace();
|
|
// fail("H5Pclose lid3: " + err);
|
|
// }
|
|
//
|
|
// // Verify that the close callback occurred
|
|
// assertTrue("H5Pclose "+((H5P_cls_close_data)cls_close_data).clsdata.get(0).cls_id ,((H5P_cls_close_data)cls_close_data).clsdata.get(0).cls_id == lid3);
|
|
// assertTrue("H5Pclose "+(((H5P_cls_close_data)cls_close_data).clsdata.get(0)).cls_count,((cdata)((H5P_cls_close_data)cls_close_data).clsdata.get(0)).cls_count==3);
|
|
// }
|
|
// finally {
|
|
// if (lid3 > 0)
|
|
// try {H5.H5Pclose(lid3);} catch (Throwable err) {}
|
|
// if (lid2 > 0)
|
|
// try {H5.H5Pclose(lid2);} catch (Throwable err) {}
|
|
// if (lid1 > 0)
|
|
// try {H5.H5Pclose(lid1);} catch (Throwable err) {}
|
|
// if (cid2 > 0)
|
|
// try {H5.H5Pclose_class(cid2);} catch (Throwable err) {}
|
|
// if (cid1 > 0)
|
|
// try {H5.H5Pclose_class(cid1);} catch (Throwable err) {}
|
|
// }
|
|
// }
|
|
|
|
}
|