aboutsummaryrefslogtreecommitdiffstats
path: root/config-model/src/test/java/com/yahoo/vespa/model/storage/DistributionBitCalculatorTest.java
blob: eef8d31bea31bf1079a4b21fbf0e913a5831f7a9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.vespa.model.storage;

import com.yahoo.vespa.model.content.DistributionBitCalculator;
import com.yahoo.vespa.model.content.cluster.ContentCluster;
import org.junit.jupiter.api.Test;

import static org.junit.jupiter.api.Assertions.assertEquals;

public class DistributionBitCalculatorTest {

    @Test
    void testBitCalculator() {
        ContentCluster.DistributionMode mode = ContentCluster.DistributionMode.STRICT;
        assertEquals(8, DistributionBitCalculator.getDistributionBits(1, mode));
        assertEquals(16, DistributionBitCalculator.getDistributionBits(10, mode));
        assertEquals(21, DistributionBitCalculator.getDistributionBits(100, mode));
        assertEquals(25, DistributionBitCalculator.getDistributionBits(500, mode));
        assertEquals(28, DistributionBitCalculator.getDistributionBits(1000, mode));

        mode = ContentCluster.DistributionMode.LOOSE;
        assertEquals(8, DistributionBitCalculator.getDistributionBits(1, mode));
        assertEquals(8, DistributionBitCalculator.getDistributionBits(4, mode));
        assertEquals(16, DistributionBitCalculator.getDistributionBits(5, mode));
        assertEquals(16, DistributionBitCalculator.getDistributionBits(199, mode));
        assertEquals(24, DistributionBitCalculator.getDistributionBits(200, mode));
        assertEquals(24, DistributionBitCalculator.getDistributionBits(2500, mode));

        mode = ContentCluster.DistributionMode.LEGACY;
        assertEquals(8, DistributionBitCalculator.getDistributionBits(1, mode));
        assertEquals(14, DistributionBitCalculator.getDistributionBits(4, mode));
        assertEquals(19, DistributionBitCalculator.getDistributionBits(16, mode));
        assertEquals(23, DistributionBitCalculator.getDistributionBits(200, mode));
        assertEquals(28, DistributionBitCalculator.getDistributionBits(2500, mode));
    }

}