#!/usr/bin/env python3
# -*- coding: utf-8 -*-

import itertools
import numpy as np

from thresholds import make_order_thresholds, make_fraction_thresholds

def test_make_order_thresholds():
    assert np.array_equal(make_order_thresholds(5, 5), [4, 3, 2, 1, 0])
    assert np.array_equal(make_order_thresholds(4, 2), [2, 0])

    for num_total_pixels, num_outer_steps in itertools.product(range(5, 50, 5), [1, 2, 3, 5]):
        thresholds = make_order_thresholds(num_total_pixels, num_outer_steps)

        #The last threshold should always be zero
        assert thresholds[-1] == 0

        # If the total number of pixels is divisible in the number of steps
        # then all steps should be the same size
        if num_total_pixels % num_outer_steps == 0:
            steps = -np.diff(np.floor(thresholds), prepend=num_total_pixels)
            assert np.array_equiv(steps, num_total_pixels // num_outer_steps)
        else:
            # otherwise, no steps should be more than 1 bigger than the other steps
            steps = -np.diff(np.floor(thresholds), prepend=num_total_pixels)
            assert np.max(steps)-np.min(steps) <= 1

def test_make_fraction_thresholds():
    assert np.array_equal(make_fraction_thresholds(2), [0.5, 1])
    assert np.array_equal(make_fraction_thresholds(4), [0.25, 0.5, 0.75, 1])