test_utils.py 9,52 ko
Newer Older
C.G.Vedant's avatar
C.G.Vedant a validé
from utils import *
import random
MircoT's avatar
MircoT a validé

norvig's avatar
norvig a validé
def test_removeall_list():
    assert removeall(4, []) == []
norvig's avatar
norvig a validé
    assert removeall(4, [1, 2, 3, 4]) == [1, 2, 3]
    assert removeall(4, [4, 1, 4, 2, 3, 4, 4]) == [1, 2, 3]
norvig's avatar
norvig a validé

MircoT's avatar
MircoT a validé

norvig's avatar
norvig a validé
def test_removeall_string():
    assert removeall('s', '') == ''
    assert removeall('s', 'This is a test. Was a test.') == 'Thi i a tet. Wa a tet.'
MircoT's avatar
MircoT a validé

norvig's avatar
norvig a validé

def test_unique():
    assert unique([1, 2, 3, 2, 1]) == [1, 2, 3]
    assert unique([1, 5, 6, 7, 6, 5]) == [1, 5, 6, 7]

MircoT's avatar
MircoT a validé

Angira Sharma's avatar
Angira Sharma a validé
def test_count():
    assert count([1, 2, 3, 4, 2, 3, 4]) == 7
    assert count("aldpeofmhngvia") == 14
    assert count([True, False, True, True, False]) == 3
    assert count([5 > 1, len("abc") == 3, 3+1 == 5]) == 2
def test_product():
MircoT's avatar
MircoT a validé
    assert product([1, 2, 3, 4]) == 24
MircoT's avatar
MircoT a validé
    assert product(list(range(1, 11))) == 3628800
MircoT's avatar
MircoT a validé

def test_first():
    assert first('word') == 'w'
    assert first('') is None
    assert first('', 'empty') == 'empty'
    assert first(range(10)) == 0
    assert first(x for x in range(10) if x > 3) == 4
    assert first(x for x in range(10) if x > 100) is None

MircoT's avatar
MircoT a validé

Chipe1's avatar
Chipe1 a validé
def test_is_in():
norvig's avatar
norvig a validé
    e = []
    assert is_in(e, [1, e, 3]) is True
    assert is_in(e, [1, [], 3]) is False
norvig's avatar
norvig a validé

MircoT's avatar
MircoT a validé

Angira Sharma's avatar
Angira Sharma a validé
def test_mode():
    assert mode([12, 32, 2, 1, 2, 3, 2, 3, 2, 3, 44, 3, 12, 4, 9, 0, 3, 45, 3]) == 3
    assert mode("absndkwoajfkalwpdlsdlfllalsflfdslgflal") == 'l'


def test_powerset():
    assert powerset([1, 2, 3]) == [(1,), (2,), (3,), (1, 2), (1, 3), (2, 3), (1, 2, 3)]


Peter Norvig's avatar
Peter Norvig a validé
def test_argminmax():
    assert argmin([-2, 1], key=abs) == 1
    assert argmax([-2, 1], key=abs) == -2
    assert argmax(['one', 'to', 'three'], key=len) == 'three'
norvig's avatar
norvig a validé

MircoT's avatar
MircoT a validé

Yu Ting's avatar
Yu Ting a validé
def test_histogram():
    assert histogram([1, 2, 4, 2, 4, 5, 7, 9, 2, 1]) == [(1, 2), (2, 3),
                                                         (4, 2), (5, 1),
                                                         (7, 1), (9, 1)]
    assert histogram([1, 2, 4, 2, 4, 5, 7, 9, 2, 1], 0, lambda x: x*x) == [(1, 2), (4, 3),
                                                                           (16, 2), (25, 1),
                                                                           (49, 1), (81, 1)]
    assert histogram([1, 2, 4, 2, 4, 5, 7, 9, 2, 1], 1) == [(2, 3), (4, 2),
                                                            (1, 2), (9, 1),
                                                            (7, 1), (5, 1)]
def test_dotproduct():
    assert dotproduct([1, 2, 3], [1000, 100, 10]) == 1230

def test_element_wise_product():
    assert element_wise_product([1, 2, 5], [7, 10, 0]) == [7, 20, 0]
    assert element_wise_product([1, 6, 3, 0], [9, 12, 0, 0]) == [9, 72, 0, 0]

def test_matrix_multiplication():
    assert matrix_multiplication([[1, 2, 3],
                                  [2, 3, 4]],
                                 [[3, 4],
                                  [1, 2],
                                  [1, 0]]) == [[8, 8], [13, 14]]

    assert matrix_multiplication([[1, 2, 3],
                                  [2, 3, 4]],
                                 [[3, 4, 8, 1],
                                  [1, 2, 5, 0],
                                  [1, 0, 0, 3]],
                                 [[1, 2],
                                  [3, 4],
                                  [5, 6],
                                  [1, 2]]) == [[132, 176], [224, 296]]


def test_vector_to_diagonal():
    assert vector_to_diagonal([1, 2, 3]) == [[1, 0, 0], [0, 2, 0], [0, 0, 3]]
    assert vector_to_diagonal([0, 3, 6]) == [[0, 0, 0], [0, 3, 0], [0, 0, 6]]
def test_vector_add():
    assert vector_add((0, 1), (8, 9)) == (8, 10)

def test_scalar_vector_product():
    assert scalar_vector_product(2, [1, 2, 3]) == [2, 4, 6]

def test_scalar_matrix_product():
    assert rounder(scalar_matrix_product(-5, [[1, 2], [3, 4], [0, 6]])) == [[-5, -10], [-15, -20],
                                                                            [0, -30]]
    assert rounder(scalar_matrix_product(0.2, [[1, 2], [2, 3]])) == [[0.2, 0.4], [0.4, 0.6]]
    assert rounder(inverse_matrix([[1, 0], [0, 1]])) == [[1, 0], [0, 1]]
    assert rounder(inverse_matrix([[2, 1], [4, 3]])) == [[1.5, -0.5], [-2.0, 1.0]]
    assert rounder(inverse_matrix([[4, 7], [2, 6]])) == [[0.6, -0.7], [-0.2, 0.4]]

    assert rounder(5.3330000300330) == 5.3330
    assert rounder(10.234566) == 10.2346
    assert rounder([1.234566, 0.555555, 6.010101]) == [1.2346, 0.5556, 6.0101]
    assert rounder([[1.234566, 0.555555, 6.010101],
                   [10.505050, 12.121212, 6.030303]]) == [[1.2346, 0.5556, 6.0101],
                                                          [10.5051, 12.1212, 6.0303]]
def test_num_or_str():
    assert num_or_str('42') == 42
    assert num_or_str(' 42x ') == '42x'

def test_normalize():
MircoT's avatar
MircoT a validé
    assert normalize([1, 2, 1]) == [0.25, 0.5, 0.25]

C.G.Vedant's avatar
C.G.Vedant a validé
def test_norm():
    assert isclose(norm([1, 2, 1], 1), 4)
    assert isclose(norm([3, 4], 2), 5)
    assert isclose(norm([-1, 1, 2], 4), 18**0.25)


def test_clip():
    assert [clip(x, 0, 1) for x in [-1, 0.5, 10]] == [0, 0.5, 1]

def test_sigmoid():
    assert isclose(0.5, sigmoid(0))
    assert isclose(0.7310585786300049, sigmoid(1))
    assert isclose(0.2689414213699951, sigmoid(-1))
def test_gaussian():
    assert gaussian(1,0.5,0.7) == 0.6664492057835993
    assert gaussian(5,2,4.5) == 0.19333405840142462
    assert gaussian(3,1,3) == 0.3989422804014327


def test_sigmoid_derivative():
    value = 1
    assert sigmoid_derivative(value) == 0

    value = 3
    assert sigmoid_derivative(value) == -6


def test_weighted_choice():
    choices = [('a', 0.5), ('b', 0.3), ('c', 0.2)]
    choice = weighted_choice(choices)
    assert choice in choices


def compare_list(x, y):
    return all([elm_x == y[i] for i, elm_x in enumerate(x)])


def test_distance():
    assert distance((1, 2), (5, 5)) == 5.0


def test_distance_squared():
    assert distance_squared((1, 2), (5, 5)) == 25.0


def test_vector_clip():
    assert vector_clip((-1, 10), (0, 0), (9, 9)) == (0, 9)


def test_turn_heading():
	assert turn_heading((0, 1), 1) == (-1, 0)
	assert turn_heading((0, 1), -1) == (1, 0)
	assert turn_heading((1, 0), 1) == (0, 1)
	assert turn_heading((1, 0), -1) == (0, -1)
	assert turn_heading((0, -1), 1) == (1, 0)
	assert turn_heading((0, -1), -1) == (-1, 0)
	assert turn_heading((-1, 0), 1) == (0, -1)
	assert turn_heading((-1, 0), -1) == (0, 1)


def test_turn_left():
	assert turn_left((0, 1)) == (-1, 0)


def test_turn_right():
	assert turn_right((0, 1)) == (1, 0)


def test_step():
Peter Norvig's avatar
Peter Norvig a validé
    assert step(1) == step(0.5) == 1
    assert step(0) == 1
Peter Norvig's avatar
Peter Norvig a validé
    assert step(-1) == step(-0.5) == 0

Peter Norvig's avatar
Peter Norvig a validé
def test_Expr():
    A, B, C = symbols('A, B, C')
    assert symbols('A, B, C') == (Symbol('A'), Symbol('B'), Symbol('C'))
    assert A.op == repr(A) == 'A'
    assert arity(A) == 0 and A.args == ()
Peter Norvig's avatar
Peter Norvig a validé
    b = Expr('+', A, 1)
    assert arity(b) == 2 and b.op == '+' and b.args == (A, 1)
Peter Norvig's avatar
Peter Norvig a validé
    u = Expr('-', b)
    assert arity(u) == 1 and u.op == '-' and u.args == (b,)
Peter Norvig's avatar
Peter Norvig a validé
    assert (b ** u) == (b ** u)
    assert (b ** u) != (u ** b)
Peter Norvig's avatar
Peter Norvig a validé
    assert A + b * C ** 2 == A + (b * (C ** 2))

    ex = C + 1 / (A % 1)
    assert list(subexpressions(ex)) == [(C + (1 / (A % 1))), C, (1 / (A % 1)), 1, (A % 1), A, 1]
    assert A in subexpressions(ex)
    assert B not in subexpressions(ex)

Peter Norvig's avatar
Peter Norvig a validé
def test_expr():
    P, Q, x, y, z, GP = symbols('P, Q, x, y, z, GP')
    assert (expr(y + 2 * x)
            == expr('y + 2 * x')
Peter Norvig's avatar
Peter Norvig a validé
            == Expr('+', y, Expr('*', 2, x)))
    assert expr('P & Q ==> P') == Expr('==>', P & Q, P)
    assert expr('P & Q <=> Q & P') == Expr('<=>', (P & Q), (Q & P))
    assert expr('P(x) | P(y) & Q(z)') == (P(x) | (P(y) & Q(z)))
    # x is grandparent of z if x is parent of y and y is parent of z:
    assert (expr('GP(x, z) <== P(x, y) & P(y, z)')
            == Expr('<==', GP(x, z), P(x, y) & P(y, z)))
def test_FIFOQueue() :
    # Create an object
    queue = FIFOQueue()
    # Generate an array of number to be used for testing
    test_data = [ random.choice(range(100)) for i in range(100) ]
    # Index of the element to be added in the queue
    front_head = 0
    # Index of the element to be removed from the queue
    back_head = 0
    while front_head < 100 or back_head < 100 :
        if front_head == 100 : # only possible to remove
            # check for pop and append method
            assert queue.pop() == test_data[back_head]
            back_head += 1
        elif back_head == front_head : # only possible to push element into queue
            queue.append(test_data[front_head])
            front_head += 1
        # else do it in a random manner
        elif random.random() < 0.5 :
            assert queue.pop() == test_data[back_head]
            back_head += 1
        else :
            queue.append(test_data[front_head])
            front_head += 1
        # check for __len__ method
        assert len(queue) == front_head - back_head
        # chek for __contains__ method
        if front_head - back_head > 0 :
            assert random.choice(test_data[back_head:front_head]) in queue

    # check extend method
    test_data1 = [ random.choice(range(100)) for i in range(50) ]
    test_data2 = [ random.choice(range(100)) for i in range(50) ]
    # append elements of test data 1
    queue.extend(test_data1)
    # append elements of test data 2
    queue.extend(test_data2)
    # reset front_head
    front_head = 0

    while front_head < 50 :
        assert test_data1[front_head] == queue.pop()
        front_head += 1

    while front_head < 100 :
        assert test_data2[front_head - 50] == queue.pop()
        front_head += 1
norvig's avatar
norvig a validé
if __name__ == '__main__':
    pytest.main()