| 1 | #include <gtest/gtest.h> | 
|---|
| 2 |  | 
|---|
| 3 | #include <DataStreams/ColumnGathererStream.h> | 
|---|
| 4 |  | 
|---|
| 5 | using DB::RowSourcePart; | 
|---|
| 6 |  | 
|---|
| 7 | static void check(const RowSourcePart & s, size_t num, bool flag) | 
|---|
| 8 | { | 
|---|
| 9 | EXPECT_FALSE((s.getSourceNum() != num || s.getSkipFlag() != flag) || (!flag && s.data != num)); | 
|---|
| 10 | } | 
|---|
| 11 |  | 
|---|
| 12 | TEST(ColumnGathererStream, RowSourcePartBitsTest) | 
|---|
| 13 | { | 
|---|
| 14 | check(RowSourcePart(0, false), 0, false); | 
|---|
| 15 | check(RowSourcePart(0, true), 0, true); | 
|---|
| 16 | check(RowSourcePart(1, false), 1, false); | 
|---|
| 17 | check(RowSourcePart(1, true), 1, true); | 
|---|
| 18 | check(RowSourcePart(RowSourcePart::MAX_PARTS, false), RowSourcePart::MAX_PARTS, false); | 
|---|
| 19 | check(RowSourcePart(RowSourcePart::MAX_PARTS, true), RowSourcePart::MAX_PARTS, true); | 
|---|
| 20 |  | 
|---|
| 21 | RowSourcePart p{80, false}; | 
|---|
| 22 | check(p, 80, false); | 
|---|
| 23 | p.setSkipFlag(true); | 
|---|
| 24 | check(p, 80, true); | 
|---|
| 25 | p.setSkipFlag(false); | 
|---|
| 26 | check(p, 80, false); | 
|---|
| 27 | p.setSourceNum(RowSourcePart::MAX_PARTS); | 
|---|
| 28 | check(p, RowSourcePart::MAX_PARTS, false); | 
|---|
| 29 | } | 
|---|
| 30 |  | 
|---|