Spaces:
Running
Running
File size: 3,085 Bytes
122d3ff |
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 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 |
# This file is part of h5py, a Python interface to the HDF5 library.
#
# http://www.h5py.org
#
# Copyright 2008-2013 Andrew Collette and contributors
#
# License: Standard 3-clause BSD; see "license.txt" for full license terms
# and contributor agreement.
"""
Tests the h5py.AttributeManager.create() method.
"""
import numpy as np
from .. import h5t, h5a
from .common import ut, TestCase
class TestArray(TestCase):
"""
Check that top-level array types can be created and read.
"""
def test_int(self):
# See issue 498
dt = np.dtype('(3,)i')
data = np.arange(3, dtype='i')
self.f.attrs.create('x', data=data, dtype=dt)
aid = h5a.open(self.f.id, b'x')
htype = aid.get_type()
self.assertEqual(htype.get_class(), h5t.ARRAY)
out = self.f.attrs['x']
self.assertArrayEqual(out, data)
def test_string_dtype(self):
# See issue 498 discussion
self.f.attrs.create('x', data=42, dtype='i8')
def test_str(self):
# See issue 1057
self.f.attrs.create('x', chr(0x03A9))
out = self.f.attrs['x']
self.assertEqual(out, chr(0x03A9))
self.assertIsInstance(out, str)
def test_tuple_of_unicode(self):
# Test that a tuple of unicode strings can be set as an attribute. It will
# be converted to a numpy array of vlen unicode type:
data = ('a', 'b')
self.f.attrs.create('x', data=data)
result = self.f.attrs['x']
self.assertTrue(all(result == data))
self.assertEqual(result.dtype, np.dtype('O'))
# However, a numpy array of type U being passed in will not be
# automatically converted, and should raise an error as it does
# not map to a h5py dtype
data_as_U_array = np.array(data)
self.assertEqual(data_as_U_array.dtype, np.dtype('U1'))
with self.assertRaises(TypeError):
self.f.attrs.create('y', data=data_as_U_array)
def test_shape(self):
self.f.attrs.create('x', data=42, shape=1)
result = self.f.attrs['x']
self.assertEqual(result.shape, (1,))
self.f.attrs.create('y', data=np.arange(3), shape=3)
result = self.f.attrs['y']
self.assertEqual(result.shape, (3,))
def test_dtype(self):
dt = np.dtype('(3,)i')
array = np.arange(3, dtype='i')
self.f.attrs.create('x', data=array, dtype=dt)
# Array dtype shape is incompatible with data shape
array = np.arange(4, dtype='i')
with self.assertRaises(ValueError):
self.f.attrs.create('x', data=array, dtype=dt)
# Shape of new attribute conflicts with shape of data
dt = np.dtype('()i')
with self.assertRaises(ValueError):
self.f.attrs.create('x', data=array, shape=(5,), dtype=dt)
def test_key_type(self):
with self.assertRaises(TypeError):
self.f.attrs.create(1, data=('a', 'b'))
|