You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

test_minddataset_exception.py 13 kB

5 years ago
5 years ago
5 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330
  1. #!/usr/bin/env python
  2. # Copyright 2019-2021 Huawei Technologies Co., Ltd
  3. #
  4. # Licensed under the Apache License, Version 2.0 (the "License");
  5. # you may not use this file except in compliance with the License.
  6. # You may obtain a copy of the License at
  7. #
  8. # http://www.apache.org/licenses/LICENSE-2.0
  9. #
  10. # Unless required by applicable law or agreed to in writing, software
  11. # distributed under the License is distributed on an "AS IS" BASIS,
  12. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. # See the License for the specific language governing permissions and
  14. # limitations under the License.
  15. # ==============================================================================
  16. import os
  17. import pytest
  18. import mindspore.dataset as ds
  19. from mindspore.mindrecord import FileWriter
  20. CV_FILE_NAME = "./imagenet.mindrecord"
  21. CV1_FILE_NAME = "./imagenet1.mindrecord"
  22. def create_cv_mindrecord(files_num):
  23. """tutorial for cv dataset writer."""
  24. if os.path.exists(CV_FILE_NAME):
  25. os.remove(CV_FILE_NAME)
  26. if os.path.exists("{}.db".format(CV_FILE_NAME)):
  27. os.remove("{}.db".format(CV_FILE_NAME))
  28. writer = FileWriter(CV_FILE_NAME, files_num)
  29. cv_schema_json = {"file_name": {"type": "string"}, "label": {"type": "int32"}, "data": {"type": "bytes"}}
  30. data = [{"file_name": "001.jpg", "label": 43, "data": bytes('0xffsafdafda', encoding='utf-8')}]
  31. writer.add_schema(cv_schema_json, "img_schema")
  32. writer.add_index(["file_name", "label"])
  33. writer.write_raw_data(data)
  34. writer.commit()
  35. def create_diff_schema_cv_mindrecord(files_num):
  36. """tutorial for cv dataset writer."""
  37. if os.path.exists(CV1_FILE_NAME):
  38. os.remove(CV1_FILE_NAME)
  39. if os.path.exists("{}.db".format(CV1_FILE_NAME)):
  40. os.remove("{}.db".format(CV1_FILE_NAME))
  41. writer = FileWriter(CV1_FILE_NAME, files_num)
  42. cv_schema_json = {"file_name_1": {"type": "string"}, "label": {"type": "int32"}, "data": {"type": "bytes"}}
  43. data = [{"file_name_1": "001.jpg", "label": 43, "data": bytes('0xffsafdafda', encoding='utf-8')}]
  44. writer.add_schema(cv_schema_json, "img_schema")
  45. writer.add_index(["file_name_1", "label"])
  46. writer.write_raw_data(data)
  47. writer.commit()
  48. def create_diff_page_size_cv_mindrecord(files_num):
  49. """tutorial for cv dataset writer."""
  50. if os.path.exists(CV1_FILE_NAME):
  51. os.remove(CV1_FILE_NAME)
  52. if os.path.exists("{}.db".format(CV1_FILE_NAME)):
  53. os.remove("{}.db".format(CV1_FILE_NAME))
  54. writer = FileWriter(CV1_FILE_NAME, files_num)
  55. writer.set_page_size(1 << 26) # 64MB
  56. cv_schema_json = {"file_name": {"type": "string"}, "label": {"type": "int32"}, "data": {"type": "bytes"}}
  57. data = [{"file_name": "001.jpg", "label": 43, "data": bytes('0xffsafdafda', encoding='utf-8')}]
  58. writer.add_schema(cv_schema_json, "img_schema")
  59. writer.add_index(["file_name", "label"])
  60. writer.write_raw_data(data)
  61. writer.commit()
  62. def test_cv_lack_json():
  63. """tutorial for cv minderdataset."""
  64. create_cv_mindrecord(1)
  65. columns_list = ["data", "file_name", "label"]
  66. num_readers = 4
  67. with pytest.raises(Exception):
  68. ds.MindDataset(CV_FILE_NAME, "no_exist.json", columns_list, num_readers)
  69. os.remove(CV_FILE_NAME)
  70. os.remove("{}.db".format(CV_FILE_NAME))
  71. def test_cv_lack_mindrecord():
  72. """tutorial for cv minderdataset."""
  73. columns_list = ["data", "file_name", "label"]
  74. num_readers = 4
  75. with pytest.raises(Exception, match="does not exist or permission denied"):
  76. _ = ds.MindDataset("no_exist.mindrecord", columns_list, num_readers)
  77. def test_invalid_mindrecord():
  78. with open('dummy.mindrecord', 'w') as f:
  79. f.write('just for test')
  80. columns_list = ["data", "file_name", "label"]
  81. num_readers = 4
  82. with pytest.raises(RuntimeError, match="Unexpected error. Invalid file content. path:"):
  83. data_set = ds.MindDataset('dummy.mindrecord', columns_list, num_readers)
  84. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  85. pass
  86. os.remove('dummy.mindrecord')
  87. def test_minddataset_lack_db():
  88. create_cv_mindrecord(1)
  89. os.remove("{}.db".format(CV_FILE_NAME))
  90. columns_list = ["data", "file_name", "label"]
  91. num_readers = 4
  92. with pytest.raises(RuntimeError, match="Unexpected error. Invalid database file:"):
  93. data_set = ds.MindDataset(CV_FILE_NAME, columns_list, num_readers)
  94. num_iter = 0
  95. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  96. num_iter += 1
  97. try:
  98. assert num_iter == 0
  99. except Exception as error:
  100. os.remove(CV_FILE_NAME)
  101. raise error
  102. else:
  103. os.remove(CV_FILE_NAME)
  104. def test_cv_minddataset_pk_sample_error_class_column():
  105. create_cv_mindrecord(1)
  106. columns_list = ["data", "file_name", "label"]
  107. num_readers = 4
  108. sampler = ds.PKSampler(5, None, True, 'no_exist_column')
  109. with pytest.raises(RuntimeError, match="Unexpected error. Failed to launch read threads."):
  110. data_set = ds.MindDataset(CV_FILE_NAME, columns_list, num_readers, sampler=sampler)
  111. num_iter = 0
  112. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  113. num_iter += 1
  114. os.remove(CV_FILE_NAME)
  115. os.remove("{}.db".format(CV_FILE_NAME))
  116. def test_cv_minddataset_pk_sample_exclusive_shuffle():
  117. create_cv_mindrecord(1)
  118. columns_list = ["data", "file_name", "label"]
  119. num_readers = 4
  120. sampler = ds.PKSampler(2)
  121. with pytest.raises(Exception, match="sampler and shuffle cannot be specified at the same time."):
  122. data_set = ds.MindDataset(CV_FILE_NAME, columns_list, num_readers,
  123. sampler=sampler, shuffle=False)
  124. num_iter = 0
  125. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  126. num_iter += 1
  127. os.remove(CV_FILE_NAME)
  128. os.remove("{}.db".format(CV_FILE_NAME))
  129. def test_cv_minddataset_reader_different_schema():
  130. create_cv_mindrecord(1)
  131. create_diff_schema_cv_mindrecord(1)
  132. columns_list = ["data", "label"]
  133. num_readers = 4
  134. with pytest.raises(RuntimeError, match="Mindrecord files meta information is different"):
  135. data_set = ds.MindDataset([CV_FILE_NAME, CV1_FILE_NAME], columns_list,
  136. num_readers)
  137. num_iter = 0
  138. for _ in data_set.create_dict_iterator(num_epochs=1):
  139. num_iter += 1
  140. os.remove(CV_FILE_NAME)
  141. os.remove("{}.db".format(CV_FILE_NAME))
  142. os.remove(CV1_FILE_NAME)
  143. os.remove("{}.db".format(CV1_FILE_NAME))
  144. def test_cv_minddataset_reader_different_page_size():
  145. create_cv_mindrecord(1)
  146. create_diff_page_size_cv_mindrecord(1)
  147. columns_list = ["data", "label"]
  148. num_readers = 4
  149. with pytest.raises(RuntimeError, match="Mindrecord files meta information is different"):
  150. data_set = ds.MindDataset([CV_FILE_NAME, CV1_FILE_NAME], columns_list,
  151. num_readers)
  152. num_iter = 0
  153. for _ in data_set.create_dict_iterator(num_epochs=1):
  154. num_iter += 1
  155. os.remove(CV_FILE_NAME)
  156. os.remove("{}.db".format(CV_FILE_NAME))
  157. os.remove(CV1_FILE_NAME)
  158. os.remove("{}.db".format(CV1_FILE_NAME))
  159. def test_minddataset_invalidate_num_shards():
  160. create_cv_mindrecord(1)
  161. columns_list = ["data", "label"]
  162. num_readers = 4
  163. with pytest.raises(Exception) as error_info:
  164. data_set = ds.MindDataset(CV_FILE_NAME, columns_list, num_readers, True, 1, 2)
  165. num_iter = 0
  166. for _ in data_set.create_dict_iterator(num_epochs=1):
  167. num_iter += 1
  168. try:
  169. assert 'Input shard_id is not within the required interval of [0, 0].' in str(error_info.value)
  170. except Exception as error:
  171. os.remove(CV_FILE_NAME)
  172. os.remove("{}.db".format(CV_FILE_NAME))
  173. raise error
  174. else:
  175. os.remove(CV_FILE_NAME)
  176. os.remove("{}.db".format(CV_FILE_NAME))
  177. def test_minddataset_invalidate_shard_id():
  178. create_cv_mindrecord(1)
  179. columns_list = ["data", "label"]
  180. num_readers = 4
  181. with pytest.raises(Exception) as error_info:
  182. data_set = ds.MindDataset(CV_FILE_NAME, columns_list, num_readers, True, 1, -1)
  183. num_iter = 0
  184. for _ in data_set.create_dict_iterator(num_epochs=1):
  185. num_iter += 1
  186. try:
  187. assert 'Input shard_id is not within the required interval of [0, 0].' in str(error_info.value)
  188. except Exception as error:
  189. os.remove(CV_FILE_NAME)
  190. os.remove("{}.db".format(CV_FILE_NAME))
  191. raise error
  192. else:
  193. os.remove(CV_FILE_NAME)
  194. os.remove("{}.db".format(CV_FILE_NAME))
  195. def test_minddataset_shard_id_bigger_than_num_shard():
  196. create_cv_mindrecord(1)
  197. columns_list = ["data", "label"]
  198. num_readers = 4
  199. with pytest.raises(Exception) as error_info:
  200. data_set = ds.MindDataset(CV_FILE_NAME, columns_list, num_readers, True, 2, 2)
  201. num_iter = 0
  202. for _ in data_set.create_dict_iterator(num_epochs=1):
  203. num_iter += 1
  204. try:
  205. assert 'Input shard_id is not within the required interval of [0, 1].' in str(error_info.value)
  206. except Exception as error:
  207. os.remove(CV_FILE_NAME)
  208. os.remove("{}.db".format(CV_FILE_NAME))
  209. raise error
  210. with pytest.raises(Exception) as error_info:
  211. data_set = ds.MindDataset(CV_FILE_NAME, columns_list, num_readers, True, 2, 5)
  212. num_iter = 0
  213. for _ in data_set.create_dict_iterator(num_epochs=1):
  214. num_iter += 1
  215. try:
  216. assert 'Input shard_id is not within the required interval of [0, 1].' in str(error_info.value)
  217. except Exception as error:
  218. os.remove(CV_FILE_NAME)
  219. os.remove("{}.db".format(CV_FILE_NAME))
  220. raise error
  221. else:
  222. os.remove(CV_FILE_NAME)
  223. os.remove("{}.db".format(CV_FILE_NAME))
  224. def test_cv_minddataset_partition_num_samples_equals_0():
  225. """tutorial for cv minddataset."""
  226. create_cv_mindrecord(1)
  227. columns_list = ["data", "label"]
  228. num_readers = 4
  229. def partitions(num_shards):
  230. for partition_id in range(num_shards):
  231. data_set = ds.MindDataset(CV_FILE_NAME, columns_list, num_readers,
  232. num_shards=num_shards,
  233. shard_id=partition_id, num_samples=-1)
  234. num_iter = 0
  235. for _ in data_set.create_dict_iterator(num_epochs=1):
  236. num_iter += 1
  237. with pytest.raises(ValueError) as error_info:
  238. partitions(5)
  239. try:
  240. assert 'num_samples exceeds the boundary between 0 and 9223372036854775807(INT64_MAX)' in str(error_info.value)
  241. except Exception as error:
  242. os.remove(CV_FILE_NAME)
  243. os.remove("{}.db".format(CV_FILE_NAME))
  244. raise error
  245. else:
  246. os.remove(CV_FILE_NAME)
  247. os.remove("{}.db".format(CV_FILE_NAME))
  248. def test_mindrecord_exception():
  249. """tutorial for exception scenario of minderdataset + map would print error info."""
  250. def exception_func(item):
  251. raise Exception("Error occur!")
  252. create_cv_mindrecord(1)
  253. columns_list = ["data", "file_name", "label"]
  254. with pytest.raises(RuntimeError, match="The corresponding data files"):
  255. data_set = ds.MindDataset(CV_FILE_NAME, columns_list, shuffle=False)
  256. data_set = data_set.map(operations=exception_func, input_columns=["data"], num_parallel_workers=1)
  257. num_iter = 0
  258. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  259. num_iter += 1
  260. with pytest.raises(RuntimeError, match="The corresponding data files"):
  261. data_set = ds.MindDataset(CV_FILE_NAME, columns_list, shuffle=False)
  262. data_set = data_set.map(operations=exception_func, input_columns=["file_name"], num_parallel_workers=1)
  263. num_iter = 0
  264. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  265. num_iter += 1
  266. with pytest.raises(RuntimeError, match="The corresponding data files"):
  267. data_set = ds.MindDataset(CV_FILE_NAME, columns_list, shuffle=False)
  268. data_set = data_set.map(operations=exception_func, input_columns=["label"], num_parallel_workers=1)
  269. num_iter = 0
  270. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  271. num_iter += 1
  272. os.remove(CV_FILE_NAME)
  273. os.remove("{}.db".format(CV_FILE_NAME))
  274. if __name__ == '__main__':
  275. test_cv_lack_json()
  276. test_cv_lack_mindrecord()
  277. test_invalid_mindrecord()
  278. test_minddataset_lack_db()
  279. test_cv_minddataset_pk_sample_error_class_column()
  280. test_cv_minddataset_pk_sample_exclusive_shuffle()
  281. test_cv_minddataset_reader_different_schema()
  282. test_cv_minddataset_reader_different_page_size()
  283. test_minddataset_invalidate_num_shards()
  284. test_minddataset_invalidate_shard_id()
  285. test_minddataset_shard_id_bigger_than_num_shard()
  286. test_cv_minddataset_partition_num_samples_equals_0()
  287. test_mindrecord_exception()