aboutsummaryrefslogtreecommitdiffstats
path: root/src/bitstream/bitstream_ut.cpp
blob: 109570b2af23db17172a0683a8ede1ea93afe6dd (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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include "bitstream.h"
#include <gtest/gtest.h>

using namespace NBitStream;

TEST(TBitStream, DefaultConstructor) {
    TBitStream bs;
    EXPECT_EQ(0u, bs.GetSizeInBits());
}

TEST(TBitStream, SimpleWriteRead) {
    TBitStream bs;
    bs.Write(5, 3);
    EXPECT_EQ(3, bs.GetSizeInBits());
    EXPECT_EQ(5, bs.Read(3));
}

TEST(TBisStream, OverlapWriteRead) {
    TBitStream bs;
    bs.Write(101, 22);
    EXPECT_EQ(22, bs.GetSizeInBits());

    bs.Write(212, 22);
    EXPECT_EQ(44, bs.GetSizeInBits());

    bs.Write(323, 22);
    EXPECT_EQ(66, bs.GetSizeInBits());

    EXPECT_EQ(101, bs.Read(22));
    EXPECT_EQ(212, bs.Read(22));
    EXPECT_EQ(323, bs.Read(22));
}
TEST(TBisStream, OverlapWriteRead2) {
    TBitStream bs;
    bs.Write(2, 2);
    bs.Write(7, 4);
    bs.Write(10003, 16);

    EXPECT_EQ(2, bs.Read(2));
    EXPECT_EQ(7, bs.Read(4));
    EXPECT_EQ(10003, bs.Read(16));
}

TEST(TBisStream, SignWriteRead) {
    TBitStream bs;
    bs.Write(MakeSign(-2, 3), 3);
    bs.Write(MakeSign(-1, 3), 3);
    bs.Write(MakeSign(1, 2), 2);
    bs.Write(MakeSign(-7, 4), 4);
    EXPECT_EQ(-2, MakeSign(bs.Read(3), 3));
    EXPECT_EQ(-1, MakeSign(bs.Read(3), 3));
    EXPECT_EQ(1, MakeSign(bs.Read(2), 2));
    EXPECT_EQ(-7, MakeSign(bs.Read(4), 4));
}