hdf5/java/test/TestH5Gbasic.java
2022-04-19 13:08:09 -05:00

488 lines
13 KiB
Java

/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Copyright by The HDF Group. *
* 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://www.hdfgroup.org/licenses. *
* 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.assertNotNull;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
import java.io.File;
import hdf.hdf5lib.H5;
import hdf.hdf5lib.HDF5Constants;
import hdf.hdf5lib.exceptions.HDF5LibraryException;
import hdf.hdf5lib.structs.H5G_info_t;
import org.junit.After;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.TestName;
public class TestH5Gbasic {
@Rule
public TestName testname = new TestName();
private static final String H5_FILE = "testGb.h5";
long H5fid = HDF5Constants.H5I_INVALID_HID;
private final long _createGroup(long fid, String name)
{
long gid = HDF5Constants.H5I_INVALID_HID;
try {
gid = H5.H5Gcreate(fid, name, HDF5Constants.H5P_DEFAULT, HDF5Constants.H5P_DEFAULT,
HDF5Constants.H5P_DEFAULT);
}
catch (Throwable err) {
err.printStackTrace();
fail("H5.H5Gcreate: " + err);
}
return gid;
}
private final void _deleteFile(String filename)
{
File file = new File(filename);
if (file.exists()) {
try {
file.delete();
}
catch (SecurityException e) {
}
}
}
@Before
public void createH5file() throws HDF5LibraryException, NullPointerException
{
assertTrue("H5 open ids is 0", H5.getOpenIDCount() == 0);
System.out.print(testname.getMethodName());
H5fid = H5.H5Fcreate(H5_FILE, HDF5Constants.H5F_ACC_TRUNC, HDF5Constants.H5P_DEFAULT,
HDF5Constants.H5P_DEFAULT);
H5.H5Fflush(H5fid, HDF5Constants.H5F_SCOPE_LOCAL);
}
@After
public void deleteH5file() throws HDF5LibraryException
{
if (H5fid > 0) {
try {
H5.H5Fclose(H5fid);
}
catch (Exception ex) {
}
}
_deleteFile(H5_FILE);
System.out.println();
}
@Test //(expected = HDF5LibraryException.class)
public void testH5Gclose_invalid() throws Throwable
{
long gid = H5.H5Gclose(-1);
assertTrue(gid == 0);
}
@Test(expected = NullPointerException.class)
public void testH5Gcreate_null() throws Throwable
{
long gid = HDF5Constants.H5I_INVALID_HID;
// it should fail because the group name is null
gid = H5.H5Gcreate(H5fid, null, HDF5Constants.H5P_DEFAULT, HDF5Constants.H5P_DEFAULT,
HDF5Constants.H5P_DEFAULT);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
}
@Test(expected = HDF5LibraryException.class)
public void testH5Gcreate_invalid() throws Throwable
{
H5.H5Gcreate(-1, "Invalid ID", HDF5Constants.H5P_DEFAULT, HDF5Constants.H5P_DEFAULT,
HDF5Constants.H5P_DEFAULT);
}
@Test
public void testH5Gcreate()
{
long gid = HDF5Constants.H5I_INVALID_HID;
try {
gid = H5.H5Gcreate(H5fid, "/testH5Gcreate", HDF5Constants.H5P_DEFAULT, HDF5Constants.H5P_DEFAULT,
HDF5Constants.H5P_DEFAULT);
}
catch (Throwable err) {
err.printStackTrace();
fail("H5.H5Gcreate: " + err);
}
assertTrue(gid > 0);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
}
@Test
public void testH5Gclose()
{
long gid = _createGroup(H5fid, "/testH5Gcreate");
assertTrue(gid > 0);
try {
H5.H5Gclose(gid);
}
catch (Throwable err) {
fail("H5Gclose: " + err);
}
}
@Test(expected = HDF5LibraryException.class)
public void testH5Gcreate_exists() throws Throwable
{
long gid = _createGroup(H5fid, "/testH5Gcreate");
assertTrue(gid > 0);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
// it should failed now because the group already exists in file
gid = H5.H5Gcreate(H5fid, "/testH5Gcreate", HDF5Constants.H5P_DEFAULT, HDF5Constants.H5P_DEFAULT,
HDF5Constants.H5P_DEFAULT);
}
@Test
public void testH5Gcreate_anon()
{
long gid = HDF5Constants.H5I_INVALID_HID;
try {
gid = H5.H5Gcreate_anon(H5fid, HDF5Constants.H5P_DEFAULT, HDF5Constants.H5P_DEFAULT);
}
catch (Throwable err) {
err.printStackTrace();
fail("H5.H5Gcreate_anon: " + err);
}
assertTrue(gid > 0);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
}
@Test(expected = NullPointerException.class)
public void testH5Gopen_null() throws Throwable
{
long gid = HDF5Constants.H5I_INVALID_HID;
gid = H5.H5Gopen(H5fid, null, HDF5Constants.H5P_DEFAULT);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
}
@Test(expected = HDF5LibraryException.class)
public void testH5Gopen_invalid() throws Throwable
{
H5.H5Gopen(-1, "Invalid ID", HDF5Constants.H5P_DEFAULT);
}
@Test(expected = HDF5LibraryException.class)
public void testH5Gopen_not_exists() throws Throwable
{
long gid = HDF5Constants.H5I_INVALID_HID;
gid = H5.H5Gopen(H5fid, "Never_created", HDF5Constants.H5P_DEFAULT);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
}
@Test
public void testH5Gopen()
{
long gid = _createGroup(H5fid, "/testH5Gcreate");
assertTrue(gid > 0);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
try {
gid = H5.H5Gopen(H5fid, "/testH5Gcreate", HDF5Constants.H5P_DEFAULT);
}
catch (Throwable err) {
err.printStackTrace();
fail("H5.H5Gopen: " + err);
}
assertTrue(gid > 0);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
}
@Test(expected = HDF5LibraryException.class)
public void testH5Gget_create_plist_invalid() throws Throwable
{
H5.H5Gget_create_plist(-1);
}
@Test
public void testH5Gget_create_plist()
{
long pid = HDF5Constants.H5I_INVALID_HID;
long gid = _createGroup(H5fid, "/testH5Gcreate");
assertTrue(gid > 0);
try {
pid = H5.H5Gget_create_plist(gid);
}
catch (Throwable err) {
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
err.printStackTrace();
fail("H5.H5Gget_create_plist: " + err);
}
assertTrue(pid > 0);
try {
H5.H5Pclose(pid);
}
catch (Exception ex) {
}
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
}
@Test(expected = HDF5LibraryException.class)
public void testH5Gget_info_invalid() throws Throwable
{
H5.H5Gget_info(-1);
}
@Test
public void testH5Gget_info()
{
H5G_info_t info = null;
long gid = _createGroup(H5fid, "/testH5Gcreate");
assertTrue(gid > 0);
try {
info = H5.H5Gget_info(gid);
}
catch (Throwable err) {
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
err.printStackTrace();
fail("H5.H5Gget_info: " + err);
}
assertNotNull(info);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
}
@Test(expected = NullPointerException.class)
public void testH5Gget_info_by_name_null() throws Throwable
{
H5.H5Gget_info_by_name(-1, null, HDF5Constants.H5P_DEFAULT);
}
@Test(expected = HDF5LibraryException.class)
public void testH5Gget_info_by_name_invalid() throws Throwable
{
H5.H5Gget_info_by_name(-1, "/testH5Gcreate", HDF5Constants.H5P_DEFAULT);
}
@Test(expected = HDF5LibraryException.class)
public void testH5Gget_info_by_name_not_exists() throws Throwable
{
H5.H5Gget_info_by_name(H5fid, "/testH5Gcreate", HDF5Constants.H5P_DEFAULT);
}
@Test
public void testH5Gget_info_by_name()
{
H5G_info_t info = null;
long gid = _createGroup(H5fid, "/testH5Gcreate");
assertTrue(gid > 0);
try {
info = H5.H5Gget_info_by_name(gid, "/testH5Gcreate", HDF5Constants.H5P_DEFAULT);
}
catch (Throwable err) {
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
err.printStackTrace();
fail("H5.H5Gget_info_by_name: " + err);
}
assertNotNull(info);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
}
@Test
public void testH5Gget_info_by_name_fileid()
{
H5G_info_t info = null;
long gid = _createGroup(H5fid, "/testH5Gcreate");
assertTrue(gid > 0);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
try {
info = H5.H5Gget_info_by_name(H5fid, "/testH5Gcreate", HDF5Constants.H5P_DEFAULT);
}
catch (Throwable err) {
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
err.printStackTrace();
fail("H5.H5Gget_info_by_name: " + err);
}
assertNotNull(info);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
}
@Test(expected = NullPointerException.class)
public void testH5Gget_info_by_idx_null() throws Throwable
{
H5.H5Gget_info_by_idx(-1, null, HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 1L,
HDF5Constants.H5P_DEFAULT);
}
@Test(expected = HDF5LibraryException.class)
public void testH5Gget_info_by_idx_invalid() throws Throwable
{
H5.H5Gget_info_by_idx(-1, "/testH5Gcreate", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC,
1L, HDF5Constants.H5P_DEFAULT);
}
@Test(expected = HDF5LibraryException.class)
public void testH5Gget_info_by_idx_not_exists() throws Throwable
{
H5.H5Gget_info_by_idx(H5fid, "/testH5Gcreate", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC,
1L, HDF5Constants.H5P_DEFAULT);
}
@Test
public void testH5Gget_info_by_idx()
{
H5G_info_t info = null;
long gid = _createGroup(H5fid, "/testH5Gcreate");
assertTrue(gid > 0);
try {
info = H5.H5Gget_info_by_idx(gid, "/", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 0,
HDF5Constants.H5P_DEFAULT);
}
catch (Throwable err) {
err.printStackTrace();
fail("H5.H5Gget_info_by_idx: " + err);
}
assertNotNull(info);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
}
@Test
public void testH5Gget_info_by_idx_fileid()
{
H5G_info_t info = null;
long gid = _createGroup(H5fid, "/testH5Gcreate");
assertTrue(gid > 0);
try {
H5.H5Gclose(gid);
}
catch (Exception ex) {
}
try {
info = H5.H5Gget_info_by_idx(H5fid, "/", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC,
0, HDF5Constants.H5P_DEFAULT);
}
catch (Throwable err) {
err.printStackTrace();
fail("H5.H5Gget_info_by_idx: " + err);
}
assertNotNull(info);
}
@Test(expected = HDF5LibraryException.class)
public void testH5Gflush_invalid() throws Throwable
{
H5.H5Gflush(-1);
}
@Test(expected = HDF5LibraryException.class)
public void testH5Grefresh_invalid() throws Throwable
{
H5.H5Grefresh(-1);
}
}