mmselfsup/tests/test_data/test_utils.py

42 lines
1.2 KiB
Python

# Copyright (c) OpenMMLab. All rights reserved.
import os.path as osp
import platform
import random
import string
import tempfile
import numpy as np
import pytest
from PIL import Image
from mmselfsup.datasets.utils import check_integrity, rm_suffix, to_numpy
def test_to_numpy():
pil_img = Image.open(
osp.join(osp.dirname(__file__), '..', 'data', 'color.jpg'))
np_img = to_numpy(pil_img)
assert type(np_img) == np.ndarray
if np_img.ndim < 3:
assert np_img.shape[0] == 1
elif np_img.ndim == 3:
assert np_img.shape[0] == 3
@pytest.mark.skipif(
platform.system() == 'Windows', reason='Windows permission')
def test_dataset_utils():
# test rm_suffix
assert rm_suffix('a.jpg') == 'a'
assert rm_suffix('a.bak.jpg') == 'a.bak'
assert rm_suffix('a.bak.jpg', suffix='.jpg') == 'a.bak'
assert rm_suffix('a.bak.jpg', suffix='.bak.jpg') == 'a'
# test check_integrity
rand_file = ''.join(random.sample(string.ascii_letters, 10))
assert not check_integrity(rand_file, md5=None)
assert not check_integrity(rand_file, md5=2333)
tmp_file = tempfile.NamedTemporaryFile()
assert check_integrity(tmp_file.name, md5=None)
assert not check_integrity(tmp_file.name, md5=2333)