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 16 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
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  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. def create_cv_mindrecord(file_name, files_num):
  21. """tutorial for cv dataset writer."""
  22. if os.path.exists(file_name):
  23. os.remove(file_name)
  24. if os.path.exists("{}.db".format(file_name)):
  25. os.remove("{}.db".format(file_name))
  26. writer = FileWriter(file_name, files_num)
  27. cv_schema_json = {"file_name": {"type": "string"},
  28. "label": {"type": "int32"}, "data": {"type": "bytes"}}
  29. data = [{"file_name": "001.jpg", "label": 43,
  30. "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(file_name, files_num):
  36. """tutorial for cv dataset writer."""
  37. if os.path.exists(file_name):
  38. os.remove(file_name)
  39. if os.path.exists("{}.db".format(file_name)):
  40. os.remove("{}.db".format(file_name))
  41. writer = FileWriter(file_name, files_num)
  42. cv_schema_json = {"file_name_1": {"type": "string"},
  43. "label": {"type": "int32"}, "data": {"type": "bytes"}}
  44. data = [{"file_name_1": "001.jpg", "label": 43,
  45. "data": bytes('0xffsafdafda', encoding='utf-8')}]
  46. writer.add_schema(cv_schema_json, "img_schema")
  47. writer.add_index(["file_name_1", "label"])
  48. writer.write_raw_data(data)
  49. writer.commit()
  50. def create_diff_page_size_cv_mindrecord(file_name, files_num):
  51. """tutorial for cv dataset writer."""
  52. if os.path.exists(file_name):
  53. os.remove(file_name)
  54. if os.path.exists("{}.db".format(file_name)):
  55. os.remove("{}.db".format(file_name))
  56. writer = FileWriter(file_name, files_num)
  57. writer.set_page_size(1 << 26) # 64MB
  58. cv_schema_json = {"file_name": {"type": "string"},
  59. "label": {"type": "int32"}, "data": {"type": "bytes"}}
  60. data = [{"file_name": "001.jpg", "label": 43,
  61. "data": bytes('0xffsafdafda', encoding='utf-8')}]
  62. writer.add_schema(cv_schema_json, "img_schema")
  63. writer.add_index(["file_name", "label"])
  64. writer.write_raw_data(data)
  65. writer.commit()
  66. def test_cv_lack_json():
  67. """tutorial for cv minderdataset."""
  68. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  69. create_cv_mindrecord(file_name, 1)
  70. columns_list = ["data", "file_name", "label"]
  71. num_readers = 4
  72. with pytest.raises(Exception):
  73. ds.MindDataset(file_name, "no_exist.json",
  74. columns_list, num_readers)
  75. os.remove(file_name)
  76. os.remove("{}.db".format(file_name))
  77. def test_cv_lack_mindrecord():
  78. """tutorial for cv minderdataset."""
  79. columns_list = ["data", "file_name", "label"]
  80. num_readers = 4
  81. with pytest.raises(Exception, match="does not exist or permission denied"):
  82. _ = ds.MindDataset("no_exist.mindrecord", columns_list, num_readers)
  83. def test_invalid_mindrecord():
  84. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  85. with open(file_name, 'w') as f:
  86. f.write('just for test')
  87. columns_list = ["data", "file_name", "label"]
  88. num_readers = 4
  89. with pytest.raises(RuntimeError, match="Unexpected error. Invalid file, the size of mindrecord file header "
  90. "is larger than the upper limit."):
  91. data_set = ds.MindDataset(file_name, columns_list, num_readers)
  92. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  93. pass
  94. os.remove(file_name)
  95. def test_minddataset_lack_db():
  96. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  97. create_cv_mindrecord(file_name, 1)
  98. os.remove("{}.db".format(file_name))
  99. columns_list = ["data", "file_name", "label"]
  100. num_readers = 4
  101. with pytest.raises(RuntimeError, match="Invalid file, failed to open mindrecord meta files "
  102. "while verifying meta file. Please check the meta file:"):
  103. data_set = ds.MindDataset(file_name, columns_list, num_readers)
  104. num_iter = 0
  105. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  106. num_iter += 1
  107. os.remove(file_name)
  108. def test_cv_minddataset_pk_sample_error_class_column():
  109. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  110. create_cv_mindrecord(file_name, 1)
  111. columns_list = ["data", "file_name", "label"]
  112. num_readers = 4
  113. sampler = ds.PKSampler(5, None, True, 'no_exist_column')
  114. with pytest.raises(RuntimeError, match="Invalid data, 'class_column': no_exist_column can not found "
  115. "in fields of mindrecord files. Please check 'class_column' in PKSampler"):
  116. data_set = ds.MindDataset(
  117. file_name, columns_list, num_readers, sampler=sampler)
  118. num_iter = 0
  119. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  120. num_iter += 1
  121. os.remove(file_name)
  122. os.remove("{}.db".format(file_name))
  123. def test_cv_minddataset_pk_sample_exclusive_shuffle():
  124. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  125. create_cv_mindrecord(file_name, 1)
  126. columns_list = ["data", "file_name", "label"]
  127. num_readers = 4
  128. sampler = ds.PKSampler(2)
  129. with pytest.raises(Exception, match="sampler and shuffle cannot be specified at the same time."):
  130. data_set = ds.MindDataset(file_name, columns_list, num_readers,
  131. sampler=sampler, shuffle=False)
  132. num_iter = 0
  133. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  134. num_iter += 1
  135. os.remove(file_name)
  136. os.remove("{}.db".format(file_name))
  137. def test_cv_minddataset_reader_different_schema():
  138. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  139. file_name_1 = file_name + '_1'
  140. create_cv_mindrecord(file_name, 1)
  141. create_diff_schema_cv_mindrecord(file_name_1, 1)
  142. columns_list = ["data", "label"]
  143. num_readers = 4
  144. with pytest.raises(RuntimeError, match="Invalid file, the metadata of mindrecord file: "
  145. "test_cv_minddataset_reader_different_schema_1 is different from others, "
  146. "please make sure all the mindrecord files generated by the same script."):
  147. data_set = ds.MindDataset([file_name, file_name_1], columns_list,
  148. num_readers)
  149. num_iter = 0
  150. for _ in data_set.create_dict_iterator(num_epochs=1):
  151. num_iter += 1
  152. os.remove(file_name)
  153. os.remove("{}.db".format(file_name))
  154. os.remove(file_name_1)
  155. os.remove("{}.db".format(file_name_1))
  156. def test_cv_minddataset_reader_different_page_size():
  157. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  158. file_name_1 = file_name + '_1'
  159. create_cv_mindrecord(file_name, 1)
  160. create_diff_page_size_cv_mindrecord(file_name_1, 1)
  161. columns_list = ["data", "label"]
  162. num_readers = 4
  163. with pytest.raises(RuntimeError, match="Invalid file, the metadata of mindrecord file: " \
  164. "test_cv_minddataset_reader_different_page_size_1 is different " \
  165. "from others, please make sure all " \
  166. "the mindrecord files generated by the same script."):
  167. data_set = ds.MindDataset([file_name, file_name_1], columns_list,
  168. num_readers)
  169. num_iter = 0
  170. for _ in data_set.create_dict_iterator(num_epochs=1):
  171. num_iter += 1
  172. os.remove(file_name)
  173. os.remove("{}.db".format(file_name))
  174. os.remove(file_name_1)
  175. os.remove("{}.db".format(file_name_1))
  176. def test_minddataset_invalidate_num_shards():
  177. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  178. create_cv_mindrecord(file_name, 1)
  179. columns_list = ["data", "label"]
  180. num_readers = 4
  181. with pytest.raises(Exception) as error_info:
  182. data_set = ds.MindDataset(
  183. file_name, columns_list, num_readers, True, 1, 2)
  184. num_iter = 0
  185. for _ in data_set.create_dict_iterator(num_epochs=1):
  186. num_iter += 1
  187. try:
  188. assert 'Input shard_id is not within the required interval of [0, 0].' in str(
  189. error_info.value)
  190. except Exception as error:
  191. os.remove(file_name)
  192. os.remove("{}.db".format(file_name))
  193. raise error
  194. else:
  195. os.remove(file_name)
  196. os.remove("{}.db".format(file_name))
  197. def test_minddataset_invalidate_shard_id():
  198. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  199. create_cv_mindrecord(file_name, 1)
  200. columns_list = ["data", "label"]
  201. num_readers = 4
  202. with pytest.raises(Exception) as error_info:
  203. data_set = ds.MindDataset(
  204. file_name, columns_list, num_readers, True, 1, -1)
  205. num_iter = 0
  206. for _ in data_set.create_dict_iterator(num_epochs=1):
  207. num_iter += 1
  208. try:
  209. assert 'Input shard_id is not within the required interval of [0, 0].' in str(
  210. error_info.value)
  211. except Exception as error:
  212. os.remove(file_name)
  213. os.remove("{}.db".format(file_name))
  214. raise error
  215. else:
  216. os.remove(file_name)
  217. os.remove("{}.db".format(file_name))
  218. def test_minddataset_shard_id_bigger_than_num_shard():
  219. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  220. create_cv_mindrecord(file_name, 1)
  221. columns_list = ["data", "label"]
  222. num_readers = 4
  223. with pytest.raises(Exception) as error_info:
  224. data_set = ds.MindDataset(
  225. file_name, columns_list, num_readers, True, 2, 2)
  226. num_iter = 0
  227. for _ in data_set.create_dict_iterator(num_epochs=1):
  228. num_iter += 1
  229. try:
  230. assert 'Input shard_id is not within the required interval of [0, 1].' in str(
  231. error_info.value)
  232. except Exception as error:
  233. os.remove(file_name)
  234. os.remove("{}.db".format(file_name))
  235. raise error
  236. with pytest.raises(Exception) as error_info:
  237. data_set = ds.MindDataset(
  238. file_name, columns_list, num_readers, True, 2, 5)
  239. num_iter = 0
  240. for _ in data_set.create_dict_iterator(num_epochs=1):
  241. num_iter += 1
  242. try:
  243. assert 'Input shard_id is not within the required interval of [0, 1].' in str(
  244. error_info.value)
  245. except Exception as error:
  246. os.remove(file_name)
  247. os.remove("{}.db".format(file_name))
  248. raise error
  249. else:
  250. os.remove(file_name)
  251. os.remove("{}.db".format(file_name))
  252. def test_cv_minddataset_partition_num_samples_equals_0():
  253. """tutorial for cv minddataset."""
  254. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  255. create_cv_mindrecord(file_name, 1)
  256. columns_list = ["data", "label"]
  257. num_readers = 4
  258. def partitions(num_shards):
  259. for partition_id in range(num_shards):
  260. data_set = ds.MindDataset(file_name, columns_list, num_readers,
  261. num_shards=num_shards,
  262. shard_id=partition_id, num_samples=-1)
  263. num_iter = 0
  264. for _ in data_set.create_dict_iterator(num_epochs=1):
  265. num_iter += 1
  266. with pytest.raises(ValueError) as error_info:
  267. partitions(5)
  268. try:
  269. assert 'num_samples exceeds the boundary between 0 and 9223372036854775807(INT64_MAX)' in str(
  270. error_info.value)
  271. except Exception as error:
  272. os.remove(file_name)
  273. os.remove("{}.db".format(file_name))
  274. raise error
  275. else:
  276. os.remove(file_name)
  277. os.remove("{}.db".format(file_name))
  278. def test_mindrecord_exception():
  279. """tutorial for exception scenario of minderdataset + map would print error info."""
  280. def exception_func(item):
  281. raise Exception("Error occur!")
  282. file_name = os.environ.get('PYTEST_CURRENT_TEST').split(':')[-1].split(' ')[0]
  283. create_cv_mindrecord(file_name, 1)
  284. columns_list = ["data", "file_name", "label"]
  285. with pytest.raises(RuntimeError, match="The corresponding data files"):
  286. data_set = ds.MindDataset(file_name, columns_list, shuffle=False)
  287. data_set = data_set.map(operations=exception_func, input_columns=["data"],
  288. num_parallel_workers=1)
  289. num_iter = 0
  290. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  291. num_iter += 1
  292. with pytest.raises(RuntimeError, match="The corresponding data files"):
  293. data_set = ds.MindDataset(file_name, columns_list, shuffle=False)
  294. data_set = data_set.map(operations=exception_func, input_columns=["file_name"],
  295. num_parallel_workers=1)
  296. num_iter = 0
  297. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  298. num_iter += 1
  299. with pytest.raises(RuntimeError, match="The corresponding data files"):
  300. data_set = ds.MindDataset(file_name, columns_list, shuffle=False)
  301. data_set = data_set.map(operations=exception_func, input_columns=["label"],
  302. num_parallel_workers=1)
  303. num_iter = 0
  304. for _ in data_set.create_dict_iterator(num_epochs=1, output_numpy=True):
  305. num_iter += 1
  306. os.remove(file_name)
  307. os.remove("{}.db".format(file_name))
  308. def test_shuffle_with_num_samples_exception():
  309. """
  310. Feature: shuffle files or shuffle samples of each file
  311. Description: set Shuffle.FILES or Shuffle.INFILE and num_samples
  312. Expectation: exception occurred
  313. """
  314. MIND_DIR = "../data/mindrecord/testMindDataSet/testImageNetData/imagenet.mindrecord0"
  315. with pytest.raises(ValueError, match="'Shuffle.FILES' or 'Shuffle.INFILE' and 'num_samples' "
  316. "cannot be specified at the same time."):
  317. _ = ds.MindDataset(MIND_DIR, shuffle=ds.Shuffle.FILES, num_samples=5)
  318. with pytest.raises(ValueError, match="'Shuffle.FILES' or 'Shuffle.INFILE' and 'num_samples' "
  319. "cannot be specified at the same time."):
  320. _ = ds.MindDataset(MIND_DIR, shuffle=ds.Shuffle.INFILE, num_samples=5)
  321. if __name__ == '__main__':
  322. test_cv_lack_json()
  323. test_cv_lack_mindrecord()
  324. test_invalid_mindrecord()
  325. test_minddataset_lack_db()
  326. test_cv_minddataset_pk_sample_error_class_column()
  327. test_cv_minddataset_pk_sample_exclusive_shuffle()
  328. test_cv_minddataset_reader_different_schema()
  329. test_cv_minddataset_reader_different_page_size()
  330. test_minddataset_invalidate_num_shards()
  331. test_minddataset_invalidate_shard_id()
  332. test_minddataset_shard_id_bigger_than_num_shard()
  333. test_cv_minddataset_partition_num_samples_equals_0()
  334. test_mindrecord_exception()