File: HDF5TimeDurationReaderTest.java

package info (click to toggle)
libsis-jhdf5-java 19.04.0%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 8,668 kB
  • sloc: java: 79,644; ansic: 18,986; sh: 309; makefile: 49; xml: 12
file content (61 lines) | stat: -rw-r--r-- 1,857 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*
 * Copyright 2007 - 2018 ETH Zuerich, CISD and SIS.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package ch.systemsx.cisd.hdf5;

import java.util.Arrays;

import org.testng.annotations.Test;

import ch.systemsx.cisd.base.mdarray.MDLongArray;

import static org.testng.AssertJUnit.*;

/**
 * Test cases for {@link HDF5TimeDurationReader}.
 * 
 * @author Bernd Rinn
 */
public class HDF5TimeDurationReaderTest
{

    @Test
    public void testConvertUnit()
    {
        MDLongArray array = new MDLongArray(new int[]
            { 5, 5, 5 });
        int[] ofs = new int[]
            { 1, 2, 1 };
        int[] dims = new int[]
            { 4, 3, 4 };
        Arrays.fill(array.getAsFlatArray(), 1);
        HDF5TimeDurationReader.convertUnit(array, HDF5TimeUnit.MINUTES, HDF5TimeUnit.SECONDS, dims,
                ofs);
        for (int x = 0; x < 5; ++x)
        {
            for (int y = 0; y < 5; ++y)
            {
                for (int z = 0; z < 5; ++z)
                {
                    final boolean converted =
                            (x >= ofs[0] && x < ofs[0] + dims[0] && y >= ofs[1]
                                    && y < ofs[1] + dims[1] && z >= ofs[2] && z < ofs[2] + dims[2]);
                    assertEquals(converted ? 60 : 1, array.get(x, y, z));
                }
            }
        }
    }
}