# -*- coding: utf-8 -*-
# Copyright (c) Vispy Development Team. All Rights Reserved.
# Distributed under the (new) BSD License. See LICENSE.txt for more info.
import numpy as np
from numpy.testing import assert_allclose

from vispy.testing import assert_raises
from vispy.geometry import resize


def test_resize():
    """Test image resizing algorithms
    """
    assert_raises(ValueError, resize, np.zeros(3), (3, 3))
    assert_raises(ValueError, resize, np.zeros((3, 3)), (3,))
    assert_raises(ValueError, resize, np.zeros((3, 3)), (4, 4), kind='foo')
    for kind, tol in (('nearest', 1e-5), ('linear', 2e-1)):
        shape = np.array((10, 11, 3))
        data = np.random.RandomState(0).rand(*shape)
        assert_allclose(data, resize(data, shape[:2], kind=kind),
                        rtol=1e-5, atol=1e-5)
        # this won't actually be that close for bilinear interp
        assert_allclose(data, resize(resize(data, 2 * shape[:2], kind=kind),
                                     shape[:2], kind=kind), atol=tol, rtol=tol)
