From 37a5ffbb1a89b21ed185fe4131668f85ff601537 Mon Sep 17 00:00:00 2001 From: Dark Knight <> Date: Thu, 5 Dec 2024 09:42:02 -0800 Subject: [PATCH] fix: Revert PR 1137 (#11743) Summary: Pull Request resolved: https://github.com/facebookincubator/velox/pull/11743 This diff reverts https://github.com/facebookincubator/velox/pull/11737 which broke dozens of tests. Reviewed By: Yuhta Differential Revision: D66773506 fbshipit-source-id: 8f0ac9ec66d1b05bee5ebd45e5e94fee6cc80120 --- .../common/base/tests/IndexedPriorityQueueTest.cpp | 1 + velox/common/base/tests/ScratchTest.cpp | 1 + velox/common/base/tests/SimdUtilTest.cpp | 1 + velox/common/memory/tests/AllocationPoolTest.cpp | 1 + .../memory/tests/ArbitrationParticipantTest.cpp | 1 + velox/common/memory/tests/MemoryAllocatorTest.cpp | 4 ++++ velox/common/memory/tests/MemoryManagerTest.cpp | 1 + velox/common/memory/tests/MemoryPoolTest.cpp | 10 ++++++++++ velox/connectors/hive/tests/HiveDataSinkTest.cpp | 1 + .../dwio/common/tests/BitPackDecoderBenchmark.cpp | 1 + velox/dwio/common/tests/IntDecoderBenchmark.cpp | 1 + velox/dwio/common/tests/utils/DataSetBuilder.cpp | 1 + velox/dwio/dwrf/test/CacheInputTest.cpp | 2 ++ velox/dwio/dwrf/test/ColumnWriterTest.cpp | 1 + velox/dwio/dwrf/test/DecryptionTests.cpp | 2 +- velox/dwio/dwrf/test/E2EReaderTest.cpp | 1 + velox/dwio/dwrf/test/E2EWriterTest.cpp | 1 + velox/dwio/parquet/reader/IntegerColumnReader.h | 1 + velox/dwio/parquet/reader/TimestampColumnReader.h | 1 + .../parquet/tests/reader/ParquetReaderTest.cpp | 4 ++++ velox/exec/HashJoinBridge.cpp | 2 +- velox/exec/fuzzer/DuckQueryRunner.cpp | 12 ++++++++++++ velox/exec/fuzzer/PrestoQueryRunner.cpp | 12 ++++++++++++ velox/exec/tests/AggregationTest.cpp | 2 ++ velox/exec/tests/HashJoinTest.cpp | 2 ++ velox/exec/tests/OutputBufferManagerTest.cpp | 1 + velox/exec/tests/PrefixSortTest.cpp | 2 ++ velox/exec/tests/RowContainerTest.cpp | 2 +- velox/exec/tests/SortBufferTest.cpp | 2 ++ velox/exec/tests/TableWriteTest.cpp | 14 ++++++++++++++ velox/exec/tests/WindowTest.cpp | 1 + velox/experimental/wave/dwio/FormatData.cpp | 1 + velox/experimental/wave/dwio/ReadStream.cpp | 1 + velox/experimental/wave/exec/ToWave.cpp | 2 ++ velox/experimental/wave/exec/WaveDriver.cpp | 2 ++ velox/expression/Expr.cpp | 2 +- velox/expression/tests/ExprTest.cpp | 1 + velox/expression/tests/GenericWriterTest.cpp | 2 ++ velox/expression/tests/MapWriterTest.cpp | 1 + velox/functions/lib/tests/KllSketchTest.cpp | 1 + .../prestosql/aggregates/tests/MapAggTest.cpp | 4 ++++ .../prestosql/benchmarks/DateTimeBenchmark.cpp | 1 + .../prestosql/benchmarks/GenericBenchmark.cpp | 3 +++ .../benchmarks/RegexpReplaceBenchmark.cpp | 3 +++ .../prestosql/tests/BinaryFunctionsTest.cpp | 7 +++++++ velox/functions/prestosql/types/IPAddressType.cpp | 1 + velox/serializers/tests/SerializerBenchmark.cpp | 1 + velox/substrait/SubstraitToVeloxPlan.cpp | 1 + velox/type/tests/FilterTest.cpp | 1 + velox/vector/DecodedVector.cpp | 2 +- velox/vector/tests/VectorCompareTest.cpp | 3 +++ velox/vector/tests/VectorTest.cpp | 1 + 52 files changed, 125 insertions(+), 5 deletions(-) diff --git a/velox/common/base/tests/IndexedPriorityQueueTest.cpp b/velox/common/base/tests/IndexedPriorityQueueTest.cpp index 0836b699b3d7..38c50a575db2 100644 --- a/velox/common/base/tests/IndexedPriorityQueueTest.cpp +++ b/velox/common/base/tests/IndexedPriorityQueueTest.cpp @@ -232,6 +232,7 @@ TEST_F(IndexedPriorityQueueTest, remove) { } TEST_F(IndexedPriorityQueueTest, fuzz) { + const int numIterations{1000}; std::mt19937 rng{100}; IndexedPriorityQueue maxQueue; fuzz(maxQueue, 1'000, rng); diff --git a/velox/common/base/tests/ScratchTest.cpp b/velox/common/base/tests/ScratchTest.cpp index 4fd4eb772781..36bdd2da2f81 100644 --- a/velox/common/base/tests/ScratchTest.cpp +++ b/velox/common/base/tests/ScratchTest.cpp @@ -35,6 +35,7 @@ TEST(ScratchTest, basic) { { ScratchPtr ints(scratch); ScratchPtr longs(scratch); + auto tempLongs = longs.get(2000); auto tempInts = ints.get(1000); std::fill(tempInts, tempInts + 1000, -1); std::fill(tempInts, tempInts + 2000, -1); diff --git a/velox/common/base/tests/SimdUtilTest.cpp b/velox/common/base/tests/SimdUtilTest.cpp index 188f0f40e7a0..2e0d26416e73 100644 --- a/velox/common/base/tests/SimdUtilTest.cpp +++ b/velox/common/base/tests/SimdUtilTest.cpp @@ -171,6 +171,7 @@ TEST_F(SimdUtilTest, gather32) { TEST_F(SimdUtilTest, gather64) { int32_t indices4[4] = {3, 2, 1, 0}; + int32_t indices3[4] = {3, 2, 1, 1 << 31}; int64_t data[4] = {44, 55, 66, 77}; constexpr int kBatchSize = xsimd::batch::size; const int32_t* indices = indices4 + (4 - kBatchSize); diff --git a/velox/common/memory/tests/AllocationPoolTest.cpp b/velox/common/memory/tests/AllocationPoolTest.cpp index 239afb2025c5..9713302744e8 100644 --- a/velox/common/memory/tests/AllocationPoolTest.cpp +++ b/velox/common/memory/tests/AllocationPoolTest.cpp @@ -53,6 +53,7 @@ TEST_F(AllocationPoolTest, hugePages) { allocationPool->setHugePageThreshold(128 << 10); int32_t counter = 0; for (;;) { + int32_t usedKB = 0; allocationPool->newRun(32 << 10); // Initial allocations round up to 64K EXPECT_EQ(1, allocationPool->numRanges()); diff --git a/velox/common/memory/tests/ArbitrationParticipantTest.cpp b/velox/common/memory/tests/ArbitrationParticipantTest.cpp index 30a2626feb97..5bb23d2c3729 100644 --- a/velox/common/memory/tests/ArbitrationParticipantTest.cpp +++ b/velox/common/memory/tests/ArbitrationParticipantTest.cpp @@ -1370,6 +1370,7 @@ DEBUG_ONLY_TEST_F(ArbitrationParticipantTest, reclaimLock) { auto task = createTask(kMemoryCapacity); const auto config = arbitrationConfig(); auto participant = ArbitrationParticipant::create(10, task->pool(), &config); + const uint64_t allocatedBytes = 32 * MB; for (int i = 0; i < 32; ++i) { task->allocate(MB); } diff --git a/velox/common/memory/tests/MemoryAllocatorTest.cpp b/velox/common/memory/tests/MemoryAllocatorTest.cpp index f0a66d0768ef..e953318c7582 100644 --- a/velox/common/memory/tests/MemoryAllocatorTest.cpp +++ b/velox/common/memory/tests/MemoryAllocatorTest.cpp @@ -637,6 +637,7 @@ TEST_P(MemoryAllocatorTest, allocationClass2) { TEST_P(MemoryAllocatorTest, stats) { const std::vector& sizes = instance_->sizeClasses(); + MachinePageCount capacity = kCapacityPages; for (auto i = 0; i < sizes.size(); ++i) { std::unique_ptr allocation = std::make_unique(); auto size = sizes[i]; @@ -962,6 +963,7 @@ TEST_P(MemoryAllocatorTest, allocContiguous) { for (const auto& testData : testSettings) { SCOPED_TRACE(fmt::format("{} useMmap{}", testData.debugString(), useMmap_)); setupAllocator(); + const MachinePageCount nonContiguousPages = 100; Allocation allocation; if (testData.nonContiguousPages != 0) { instance_->allocateNonContiguous(testData.nonContiguousPages, allocation); @@ -1063,6 +1065,7 @@ TEST_P(MemoryAllocatorTest, allocContiguousFail) { SCOPED_TRACE( fmt::format("{} useMmap {}", testData.debugString(), useMmap_)); setupAllocator(); + const MachinePageCount nonContiguousPages = 100; Allocation allocation; if (testData.nonContiguousPages != 0) { instance_->allocateNonContiguous(testData.nonContiguousPages, allocation); @@ -1373,6 +1376,7 @@ TEST_P(MemoryAllocatorTest, StlMemoryAllocator) { // Allocation from classes and ContiguousAllocation outside size // classes. constexpr int32_t kNumDoubles = 256 * 1024; + size_t capacity = 0; for (auto i = 0; i < kNumDoubles; i++) { data.push_back(i); } diff --git a/velox/common/memory/tests/MemoryManagerTest.cpp b/velox/common/memory/tests/MemoryManagerTest.cpp index b241e0f2f71d..c4a7329cf8ef 100644 --- a/velox/common/memory/tests/MemoryManagerTest.cpp +++ b/velox/common/memory/tests/MemoryManagerTest.cpp @@ -554,6 +554,7 @@ TEST_F(MemoryManagerTest, concurrentPoolAccess) { std::atomic stopCheck{false}; std::thread checkThread([&]() { while (!stopCheck) { + const int numPools = manager.numPools(); std::this_thread::sleep_for(std::chrono::microseconds(1)); } }); diff --git a/velox/common/memory/tests/MemoryPoolTest.cpp b/velox/common/memory/tests/MemoryPoolTest.cpp index 3eb2df723a2e..28e7732624a4 100644 --- a/velox/common/memory/tests/MemoryPoolTest.cpp +++ b/velox/common/memory/tests/MemoryPoolTest.cpp @@ -144,6 +144,7 @@ class MemoryPoolTest : public testing::TestWithParam { }; TEST_P(MemoryPoolTest, ctor) { + constexpr uint16_t kAlignment = 64; setupMemory({.alignment = 64, .allocatorCapacity = kDefaultCapacity}); MemoryManager& manager = *getMemoryManager(); const int64_t capacity = 4 * GB; @@ -689,6 +690,7 @@ TEST_P(MemoryPoolTest, alignmentCheck) { ASSERT_EQ( pool->alignment(), alignment == 0 ? MemoryAllocator::kMinAlignment : alignment); + const int32_t kTestIterations = 10; for (int32_t i = 0; i < 10; ++i) { const int64_t bytesToAlloc = 1 + folly::Random::rand32() % (1 * MB); void* ptr = pool->allocate(bytesToAlloc); @@ -1026,6 +1028,11 @@ TEST_P(MemoryPoolTest, contiguousAllocate) { ASSERT_GE(numAllocatedPages, 0); allocations.erase(allocations.begin() + freeAllocationIdx); } + const MachinePageCount minSizeClass = folly::Random().oneIn(4) + ? 0 + : std::min( + manager->allocator()->largestSizeClass(), + folly::Random().rand32() % kMaxAllocationPages); pool->allocateContiguous(pagesToAllocate, allocation); numAllocatedPages += allocation.numPages(); for (int32_t j = 0; j < allocation.size(); ++j) { @@ -1075,6 +1082,7 @@ TEST_P(MemoryPoolTest, contiguousAllocateExceedLimit) { TEST_P(MemoryPoolTest, badContiguousAllocation) { auto manager = getMemoryManager(); auto pool = manager->addLeafPool("badContiguousAllocation"); + constexpr MachinePageCount kAllocSize = 8; ContiguousAllocation allocation; ASSERT_THROW(pool->allocateContiguous(0, allocation), VeloxRuntimeError); } @@ -2492,6 +2500,7 @@ TEST_P(MemoryPoolTest, concurrentUpdateToSharedPools) { TEST_P(MemoryPoolTest, concurrentPoolStructureAccess) { folly::Random::DefaultGenerator rng; rng.seed(1234); + constexpr int64_t kMaxMemory = 8 * GB; MemoryManager& manager = *getMemoryManager(); auto root = manager.addRootPool(); std::atomic poolId{0}; @@ -2656,6 +2665,7 @@ TEST(MemoryPoolTest, debugMode) { TEST(MemoryPoolTest, debugModeWithFilter) { constexpr int64_t kMaxMemory = 10 * GB; + constexpr int64_t kNumIterations = 100; const std::vector kAllocSizes = {128, 8 * KB, 2 * MB}; const std::vector debugEnabledSet{true, false}; for (const auto& debugEnabled : debugEnabledSet) { diff --git a/velox/connectors/hive/tests/HiveDataSinkTest.cpp b/velox/connectors/hive/tests/HiveDataSinkTest.cpp index 36e806d8dae8..b2ea57af281b 100644 --- a/velox/connectors/hive/tests/HiveDataSinkTest.cpp +++ b/velox/connectors/hive/tests/HiveDataSinkTest.cpp @@ -976,6 +976,7 @@ DEBUG_ONLY_TEST_F(HiveDataSinkTest, sortWriterAbortDuringFinish) { dataSink->appendData(vector); } + std::atomic_int injectCount{0}; SCOPED_TESTVALUE_SET( "facebook::velox::dwrf::Writer::write", std::function([&](dwrf::Writer* /*unused*/) { diff --git a/velox/dwio/common/tests/BitPackDecoderBenchmark.cpp b/velox/dwio/common/tests/BitPackDecoderBenchmark.cpp index 6f42b42e9959..63b87d86cebe 100644 --- a/velox/dwio/common/tests/BitPackDecoderBenchmark.cpp +++ b/velox/dwio/common/tests/BitPackDecoderBenchmark.cpp @@ -542,6 +542,7 @@ void naiveDecodeBitsLE( } return; } + auto lastSafe = bufferEnd - sizeof(uint64_t); int32_t numSafeRows = numRows; bool anyUnsafe = false; if (bufferEnd) { diff --git a/velox/dwio/common/tests/IntDecoderBenchmark.cpp b/velox/dwio/common/tests/IntDecoderBenchmark.cpp index 9918c1b25063..48e61768a227 100644 --- a/velox/dwio/common/tests/IntDecoderBenchmark.cpp +++ b/velox/dwio/common/tests/IntDecoderBenchmark.cpp @@ -910,6 +910,7 @@ BENCHMARK_RELATIVE(decodeNew_16) { BENCHMARK(decodeOld_32) { size_t currentLen = len_u32; const size_t startingLen = len_u32; + int32_t i = 0; while (currentLen != 0) { auto result = readVuLong(buffer_u32.data() + (startingLen - currentLen), currentLen); diff --git a/velox/dwio/common/tests/utils/DataSetBuilder.cpp b/velox/dwio/common/tests/utils/DataSetBuilder.cpp index 85c508dd0a3b..07b6b245003f 100644 --- a/velox/dwio/common/tests/utils/DataSetBuilder.cpp +++ b/velox/dwio/common/tests/utils/DataSetBuilder.cpp @@ -254,6 +254,7 @@ DataSetBuilder& DataSetBuilder::makeMapStringValues( auto keyKind = map->type()->childAt(0)->kind(); auto valueKind = map->type()->childAt(1)->kind(); auto offsets = map->rawOffsets(); + auto sizes = map->rawSizes(); int32_t offsetIndex = 0; auto mapSize = map->size(); auto getNextOffset = [&]() { diff --git a/velox/dwio/dwrf/test/CacheInputTest.cpp b/velox/dwio/dwrf/test/CacheInputTest.cpp index 927058c5c5c4..0c8214017817 100644 --- a/velox/dwio/dwrf/test/CacheInputTest.cpp +++ b/velox/dwio/dwrf/test/CacheInputTest.cpp @@ -476,6 +476,8 @@ TEST_F(CacheTest, window) { auto cacheInput = dynamic_cast(stream.get()); EXPECT_TRUE(cacheInput != nullptr); ASSERT_EQ(cacheInput->getName(), "CacheInputStream 0 of 13631488"); + auto maxSize = + allocator_->sizeClasses().back() * memory::AllocationTraits::kPageSize; const void* buffer; int32_t size; int32_t numRead = 0; diff --git a/velox/dwio/dwrf/test/ColumnWriterTest.cpp b/velox/dwio/dwrf/test/ColumnWriterTest.cpp index 2343e489d689..d03d7dc98ba0 100644 --- a/velox/dwio/dwrf/test/ColumnWriterTest.cpp +++ b/velox/dwio/dwrf/test/ColumnWriterTest.cpp @@ -1873,6 +1873,7 @@ int64_t generateRangeWithCustomLimits( // Generate the range such that we have similar amounts of values generated // for each exponent. double center = size % 2 ? -0.5 : interval / 2 - 0.5; + double value = center + (i - size / 2) * interval; // Return a guard-railed value with the numeric limits. // NOTE: There can be a more compact way to write this if we cast i and size // to signed types, but it's not worth the effort enforcing the assumptions. diff --git a/velox/dwio/dwrf/test/DecryptionTests.cpp b/velox/dwio/dwrf/test/DecryptionTests.cpp index 6a19a41c4846..10c3ec089aa2 100644 --- a/velox/dwio/dwrf/test/DecryptionTests.cpp +++ b/velox/dwio/dwrf/test/DecryptionTests.cpp @@ -43,7 +43,7 @@ TEST(Decryption, NoKeyProvider) { auto type = parser.parse("struct"); proto::Footer footer; ProtoUtils::writeType(*type, footer); - footer.mutable_encryption(); + auto enc = footer.mutable_encryption(); TestDecrypterFactory factory; ASSERT_THROW( DecryptionHandler::create(footer, &factory), exception::LoggedException); diff --git a/velox/dwio/dwrf/test/E2EReaderTest.cpp b/velox/dwio/dwrf/test/E2EReaderTest.cpp index 67fa766c1e72..3e3ab15f1964 100644 --- a/velox/dwio/dwrf/test/E2EReaderTest.cpp +++ b/velox/dwio/dwrf/test/E2EReaderTest.cpp @@ -231,6 +231,7 @@ TEST_P(E2EReaderTest, SharedDictionaryFlatmapReadAsStruct) { ASSERT_TRUE(resultTypeRow.childAt(col)->isMap()); ASSERT_EQ(batchRow->childAt(col)->typeKind(), TypeKind::MAP); auto& resultTypeChild = resultTypeRow.childAt(col)->as(); + auto* batchRowChild = batchRow->childAt(col)->as(); ASSERT_EQ( resultTypeChild.keyType()->kind(), schemaChild.keyType()->kind()); ASSERT_EQ( diff --git a/velox/dwio/dwrf/test/E2EWriterTest.cpp b/velox/dwio/dwrf/test/E2EWriterTest.cpp index d24941fed0a3..2b34f2f81ea7 100644 --- a/velox/dwio/dwrf/test/E2EWriterTest.cpp +++ b/velox/dwio/dwrf/test/E2EWriterTest.cpp @@ -1960,6 +1960,7 @@ TEST_F(E2EWriterTest, memoryReclaimAfterClose) { VELOX_ASSERT_THROW(writer->flush(), "Writer is not running"); memory::MemoryReclaimer::Stats stats; + const auto oldCapacity = writerPool->capacity(); writerPool->reclaim(1L << 30, 0, stats); if (testData.abort || !testData.canReclaim) { ASSERT_EQ(stats.numNonReclaimableAttempts, 0); diff --git a/velox/dwio/parquet/reader/IntegerColumnReader.h b/velox/dwio/parquet/reader/IntegerColumnReader.h index 8c2aa2b4df16..3c34e01bdaa4 100644 --- a/velox/dwio/parquet/reader/IntegerColumnReader.h +++ b/velox/dwio/parquet/reader/IntegerColumnReader.h @@ -68,6 +68,7 @@ class IntegerColumnReader : public dwio::common::SelectiveIntegerColumnReader { int64_t offset, const RowSet& rows, const uint64_t* /*incomingNulls*/) override { + auto& data = formatData_->as(); VELOX_WIDTH_DISPATCH( parquetSizeOfIntKind(fileType_->type()->kind()), prepareRead, diff --git a/velox/dwio/parquet/reader/TimestampColumnReader.h b/velox/dwio/parquet/reader/TimestampColumnReader.h index 18e745418f69..5864cc31f1cb 100644 --- a/velox/dwio/parquet/reader/TimestampColumnReader.h +++ b/velox/dwio/parquet/reader/TimestampColumnReader.h @@ -133,6 +133,7 @@ class TimestampColumnReader : public IntegerColumnReader { int64_t offset, const RowSet& rows, const uint64_t* /*incomingNulls*/) override { + auto& data = formatData_->as(); // Use int128_t as a workaround. Timestamp in Velox is of 16-byte length. prepareRead(offset, rows, nullptr); readCommon(rows); diff --git a/velox/dwio/parquet/tests/reader/ParquetReaderTest.cpp b/velox/dwio/parquet/tests/reader/ParquetReaderTest.cpp index 79251e2b381f..e860118eefd5 100644 --- a/velox/dwio/parquet/tests/reader/ParquetReaderTest.cpp +++ b/velox/dwio/parquet/tests/reader/ParquetReaderTest.cpp @@ -1365,6 +1365,7 @@ TEST_F(ParquetReaderTest, arrayOfMapOfIntKeyArrayValue) { facebook::velox::dwio::common::ReaderOptions readerOptions{leafPool_.get()}; auto reader = createReader(sample, readerOptions); EXPECT_EQ(reader->rowType()->toString(), expectedVeloxType); + auto numRows = reader->numberOfRows(); auto type = reader->typeWithId(); RowReaderOptions rowReaderOpts; auto rowType = ROW({"test"}, {ARRAY(MAP(VARCHAR(), ARRAY(INTEGER())))}); @@ -1398,6 +1399,7 @@ TEST_F(ParquetReaderTest, arrayOfMapOfIntKeyStructValue) { facebook::velox::dwio::common::ReaderOptions readerOptions{leafPool_.get()}; auto reader = createReader(sample, readerOptions); EXPECT_EQ(reader->rowType()->toString(), expectedVeloxType); + auto numRows = reader->numberOfRows(); auto type = reader->typeWithId(); RowReaderOptions rowReaderOpts; auto rowType = reader->rowType(); @@ -1431,6 +1433,7 @@ TEST_F(ParquetReaderTest, struct_of_array_of_array) { getExampleFilePath("struct_of_array_of_array.parquet")); facebook::velox::dwio::common::ReaderOptions readerOptions{leafPool_.get()}; auto reader = createReader(sample, readerOptions); + auto numRows = reader->numberOfRows(); auto type = reader->typeWithId(); EXPECT_EQ(type->size(), 1ULL); EXPECT_EQ(reader->rowType()->toString(), expectedVeloxType); @@ -1504,6 +1507,7 @@ TEST_F(ParquetReaderTest, testLzoDataPage) { rowReaderOpts.setScanSpec(makeScanSpec(outputRowType)); auto rowReader = reader->createRowReader(rowReaderOpts); + uint64_t total = 0; VectorPtr result = BaseVector::create(outputRowType, 0, &*leafPool_); rowReader->next(23'547ULL, result); EXPECT_EQ(23'547ULL, result->size()); diff --git a/velox/exec/HashJoinBridge.cpp b/velox/exec/HashJoinBridge.cpp index 4c8b4e54c5d6..8961affb15b8 100644 --- a/velox/exec/HashJoinBridge.cpp +++ b/velox/exec/HashJoinBridge.cpp @@ -256,7 +256,7 @@ void HashJoinBridge::appendSpilledHashTablePartitionsLocked( } auto spillPartitionIdSet = toSpillPartitionIdSet(spillPartitionSet); if (restoringSpillPartitionId_.has_value()) { - for ([[maybe_unused]] const auto& id : spillPartitionIdSet) { + for (const auto& id : spillPartitionIdSet) { VELOX_DCHECK_LT( restoringSpillPartitionId_->partitionBitOffset(), id.partitionBitOffset()); diff --git a/velox/exec/fuzzer/DuckQueryRunner.cpp b/velox/exec/fuzzer/DuckQueryRunner.cpp index 603c8f00b4f2..15b74efae88e 100644 --- a/velox/exec/fuzzer/DuckQueryRunner.cpp +++ b/velox/exec/fuzzer/DuckQueryRunner.cpp @@ -423,6 +423,18 @@ std::optional DuckQueryRunner::toSql( std::optional DuckQueryRunner::toSql( const std::shared_ptr& joinNode) { + const auto& joinKeysToSql = [](auto keys) { + std::stringstream out; + for (auto i = 0; i < keys.size(); ++i) { + if (i > 0) { + out << ", "; + } + out << keys[i]->name(); + } + return out.str(); + }; + + const auto& outputNames = joinNode->outputType()->names(); std::stringstream sql; // Nested loop join without filter. diff --git a/velox/exec/fuzzer/PrestoQueryRunner.cpp b/velox/exec/fuzzer/PrestoQueryRunner.cpp index 3ab8689030da..0a22bae47bf8 100644 --- a/velox/exec/fuzzer/PrestoQueryRunner.cpp +++ b/velox/exec/fuzzer/PrestoQueryRunner.cpp @@ -638,6 +638,18 @@ std::optional PrestoQueryRunner::toSql( std::optional PrestoQueryRunner::toSql( const std::shared_ptr& joinNode) { + const auto& joinKeysToSql = [](auto keys) { + std::stringstream out; + for (auto i = 0; i < keys.size(); ++i) { + if (i > 0) { + out << ", "; + } + out << keys[i]->name(); + } + return out.str(); + }; + + const auto& outputNames = joinNode->outputType()->names(); std::stringstream sql; // Nested loop join without filter. diff --git a/velox/exec/tests/AggregationTest.cpp b/velox/exec/tests/AggregationTest.cpp index 4dd223aa326a..85ccb53bb651 100644 --- a/velox/exec/tests/AggregationTest.cpp +++ b/velox/exec/tests/AggregationTest.cpp @@ -1012,6 +1012,7 @@ TEST_F(AggregationTest, largeValueRangeArray) { TEST_F(AggregationTest, partialAggregationMemoryLimitIncrease) { constexpr int64_t kGB = 1 << 30; + constexpr int64_t kB = 1 << 10; auto vectors = { makeRowVector({makeFlatVector( 100, [](auto row) { return row; }, nullEvery(5))}), @@ -1103,6 +1104,7 @@ TEST_F(AggregationTest, partialAggregationMaybeReservationReleaseCheck) { constexpr int64_t kGB = 1 << 30; const int64_t kMaxPartialMemoryUsage = 1 * kGB; + const int64_t kMaxUserMemoryUsage = 2 * kMaxPartialMemoryUsage; // Make sure partial aggregation runs out of memory after first batch. CursorParameters params; params.queryCtx = core::QueryCtx::create(executor_.get()); diff --git a/velox/exec/tests/HashJoinTest.cpp b/velox/exec/tests/HashJoinTest.cpp index dba7a6593cdd..470b9026b403 100644 --- a/velox/exec/tests/HashJoinTest.cpp +++ b/velox/exec/tests/HashJoinTest.cpp @@ -6816,6 +6816,7 @@ TEST_F(HashJoinTest, leftJoinPreserveProbeOrder) { } DEBUG_ONLY_TEST_F(HashJoinTest, minSpillableMemoryReservation) { + constexpr int64_t kMaxBytes = 1LL << 30; // 1GB VectorFuzzer fuzzer({.vectorSize = 1000}, pool()); const int32_t numBuildVectors = 10; std::vector buildVectors; @@ -7365,6 +7366,7 @@ DEBUG_ONLY_TEST_F(HashJoinTest, exceptionDuringFinishJoinBuild) { DEBUG_ONLY_TEST_F(HashJoinTest, arbitrationTriggeredDuringParallelJoinBuild) { std::unique_ptr memoryManager = createMemoryManager(); + const auto& arbitrator = memoryManager->arbitrator(); const uint64_t numDrivers = 2; // Large build side key product to bump hash mode to kHash instead of kArray diff --git a/velox/exec/tests/OutputBufferManagerTest.cpp b/velox/exec/tests/OutputBufferManagerTest.cpp index 3902ead5ffc4..e341ae4329fe 100644 --- a/velox/exec/tests/OutputBufferManagerTest.cpp +++ b/velox/exec/tests/OutputBufferManagerTest.cpp @@ -329,6 +329,7 @@ class OutputBufferManagerTest : public testing::Test { return; } const int64_t maxBytes = folly::Random().oneIn(4, rng) ? 32'000'000 : 1; + int64_t receivedSequence; bool atEnd{false}; folly::EventCount dataWait; auto dataWaitKey = dataWait.prepareWait(); diff --git a/velox/exec/tests/PrefixSortTest.cpp b/velox/exec/tests/PrefixSortTest.cpp index 6213834f3c90..248d1473bd0d 100644 --- a/velox/exec/tests/PrefixSortTest.cpp +++ b/velox/exec/tests/PrefixSortTest.cpp @@ -151,6 +151,7 @@ const RowVectorPtr PrefixSortTest::generateExpectedResult( } TEST_F(PrefixSortTest, singleKey) { + const int numRows = 5; const int columnsSize = 7; // Vectors without nulls. @@ -182,6 +183,7 @@ TEST_F(PrefixSortTest, singleKey) { } TEST_F(PrefixSortTest, singleKeyWithNulls) { + const int numRows = 5; const int columnsSize = 7; Timestamp ts = {5, 5}; diff --git a/velox/exec/tests/RowContainerTest.cpp b/velox/exec/tests/RowContainerTest.cpp index 36d7138df244..180515b85da1 100644 --- a/velox/exec/tests/RowContainerTest.cpp +++ b/velox/exec/tests/RowContainerTest.cpp @@ -2479,7 +2479,7 @@ TEST_F(RowContainerTest, invalidatedColumnStats) { EXPECT_EQ(data->columnStats(4)->numCells(), 0); for (int i = 0; i < kNumRows; ++i) { - data->newRow(); + auto row = data->newRow(); } EXPECT_EQ(kNumRows, data->numRows()); RowContainerIterator iter; diff --git a/velox/exec/tests/SortBufferTest.cpp b/velox/exec/tests/SortBufferTest.cpp index 1bde98261954..8ebb04f9b0fb 100644 --- a/velox/exec/tests/SortBufferTest.cpp +++ b/velox/exec/tests/SortBufferTest.cpp @@ -503,6 +503,7 @@ DEBUG_ONLY_TEST_P(SortBufferTest, spillDuringInput) { const std::shared_ptr fuzzerPool = memory::memoryManager()->addLeafPool("spillDuringInput"); VectorFuzzer fuzzer({.vectorSize = 1024}, fuzzerPool.get()); + uint64_t totalNumInput{0}; ASSERT_EQ(memory::spillMemoryPool()->stats().usedBytes, 0); const auto peakSpillMemoryUsage = @@ -554,6 +555,7 @@ DEBUG_ONLY_TEST_P(SortBufferTest, spillDuringOutput) { const std::shared_ptr fuzzerPool = memory::memoryManager()->addLeafPool("spillDuringOutput"); VectorFuzzer fuzzer({.vectorSize = 1024}, fuzzerPool.get()); + uint64_t totalNumInput{0}; ASSERT_EQ(memory::spillMemoryPool()->stats().usedBytes, 0); const auto peakSpillMemoryUsage = diff --git a/velox/exec/tests/TableWriteTest.cpp b/velox/exec/tests/TableWriteTest.cpp index b34d33245f85..507159493a5a 100644 --- a/velox/exec/tests/TableWriteTest.cpp +++ b/velox/exec/tests/TableWriteTest.cpp @@ -2330,6 +2330,7 @@ TEST_P(PartitionedTableWriterTest, singlePartition) { } TEST_P(PartitionedWithoutBucketTableWriterTest, fromSinglePartitionToMultiple) { + const int32_t numBatches = 1; auto rowType = ROW({"c0", "c1"}, {BIGINT(), BIGINT()}); setDataTypes(rowType); std::vector partitionKeys = {"c0"}; @@ -3076,6 +3077,8 @@ TEST_P(AllTableWriterTest, columnStatsDataTypes) { const auto countStatsVector = result->childAt(nextColumnStatsIndex++)->asFlatVector(); ASSERT_EQ(countStatsVector->valueAt(0), 1000); + const auto countIfStatsVector = + result->childAt(nextColumnStatsIndex++)->asFlatVector(); ASSERT_EQ(countStatsVector->valueAt(0), 1000); const auto countMapStatsVector = result->childAt(nextColumnStatsIndex++)->asFlatVector(); @@ -3142,10 +3145,13 @@ TEST_P(AllTableWriterTest, columnStats) { auto result = AssertQueryBuilder(plan).copyResults(pool()); auto rowVector = result->childAt(0)->asFlatVector(); auto fragmentVector = result->childAt(1)->asFlatVector(); + auto commitContextVector = result->childAt(2)->asFlatVector(); auto columnStatsVector = result->childAt(3 + partitionedBy_.size())->asFlatVector(); + const int64_t expectedRows = 10 * 100; std::vector writeFiles; + int64_t numRows{0}; // For partitioned, expected result is as follows: // Row Fragment Context partition c1_min_value @@ -3249,10 +3255,13 @@ TEST_P(AllTableWriterTest, columnStatsWithTableWriteMerge) { auto result = AssertQueryBuilder(finalPlan).copyResults(pool()); auto rowVector = result->childAt(0)->asFlatVector(); auto fragmentVector = result->childAt(1)->asFlatVector(); + auto commitContextVector = result->childAt(2)->asFlatVector(); auto columnStatsVector = result->childAt(3 + partitionedBy_.size())->asFlatVector(); + const int64_t expectedRows = 10 * 100; std::vector writeFiles; + int64_t numRows{0}; // For partitioned, expected result is as follows: // Row Fragment Context partition c1_min_value @@ -4378,6 +4387,7 @@ DEBUG_ONLY_TEST_F( } DEBUG_ONLY_TEST_F(TableWriterArbitrationTest, tableFileWriteError) { + const uint64_t memoryCapacity = 32 * MB; VectorFuzzer::Options options; const int batchSize = 1'000; options.vectorSize = batchSize; @@ -4394,6 +4404,7 @@ DEBUG_ONLY_TEST_F(TableWriterArbitrationTest, tableFileWriteError) { auto queryPool = memory::memoryManager()->addRootPool( "tableFileWriteError", kQueryMemoryCapacity); + auto* arbitrator = memory::memoryManager()->arbitrator(); auto queryCtx = core::QueryCtx::create( executor_.get(), QueryConfig{{}}, {}, nullptr, std::move(queryPool)); ASSERT_EQ(queryCtx->pool()->capacity(), kQueryMemoryCapacity); @@ -4449,6 +4460,7 @@ DEBUG_ONLY_TEST_F(TableWriterArbitrationTest, tableFileWriteError) { } DEBUG_ONLY_TEST_F(TableWriterArbitrationTest, tableWriteSpillUseMoreMemory) { + const uint64_t memoryCapacity = 256 * MB; // Create a large number of vectors to trigger writer spill. fuzzerOpts_.vectorSize = 1000; fuzzerOpts_.stringLength = 2048; @@ -4474,6 +4486,7 @@ DEBUG_ONLY_TEST_F(TableWriterArbitrationTest, tableWriteSpillUseMoreMemory) { fakeLeafPool->allocate(fakeAllocationSize), fakeAllocationSize}; + void* allocatedBuffer; TestAllocation injectedWriterAllocation; SCOPED_TESTVALUE_SET( "facebook::velox::dwrf::Writer::flushInternal", @@ -4547,6 +4560,7 @@ DEBUG_ONLY_TEST_F(TableWriterArbitrationTest, tableWriteReclaimOnClose) { numRows += vectors.back()->size(); } + auto* arbitrator = memory::memoryManager()->arbitrator(); auto queryPool = memory::memoryManager()->addRootPool( "tableWriteSpillUseMoreMemory", kQueryMemoryCapacity); auto queryCtx = core::QueryCtx::create( diff --git a/velox/exec/tests/WindowTest.cpp b/velox/exec/tests/WindowTest.cpp index a89490283804..a725d359207d 100644 --- a/velox/exec/tests/WindowTest.cpp +++ b/velox/exec/tests/WindowTest.cpp @@ -504,6 +504,7 @@ TEST_F(WindowTest, nagativeFrameArg) { auto sizeAt = [](vector_size_t row) { return row % 5; }; auto keyAt = [](vector_size_t row) { return row % 11; }; + auto valueAt = [](vector_size_t row) { return row % 13; }; auto keys = makeArrayVector(size, sizeAt, keyAt); auto data = makeRowVector( {"c0", "c1", "p0", "p1", "k0", "row_number"}, diff --git a/velox/experimental/wave/dwio/FormatData.cpp b/velox/experimental/wave/dwio/FormatData.cpp index 0080424d3572..feb847aa6f7d 100644 --- a/velox/experimental/wave/dwio/FormatData.cpp +++ b/velox/experimental/wave/dwio/FormatData.cpp @@ -96,6 +96,7 @@ void SplitStaging::transfer( hostBuffer_ = getTransferArena().allocate(fill_); auto transferBuffer = hostBuffer_->as(); int firstToCopy = 0; + int32_t numCopies = staging_.size(); int64_t copySize = 0; auto targetCopySize = FLAGS_staging_bytes_per_thread; int32_t numThreads = 0; diff --git a/velox/experimental/wave/dwio/ReadStream.cpp b/velox/experimental/wave/dwio/ReadStream.cpp index 922c1476659b..af8f52ac3c6b 100644 --- a/velox/experimental/wave/dwio/ReadStream.cpp +++ b/velox/experimental/wave/dwio/ReadStream.cpp @@ -352,6 +352,7 @@ void ReadStream::launch( // kBlockSize top level rows of output and to have Operand structs for the // produced column. readStream->makeControl(); + auto numRows = readStream->rows_.size(); auto waveStream = readStream->waveStream; WaveStats& stats = waveStream->stats(); bool firstLaunch = true; diff --git a/velox/experimental/wave/exec/ToWave.cpp b/velox/experimental/wave/exec/ToWave.cpp index 1b66a815b0cf..c1c4ce4c12f8 100644 --- a/velox/experimental/wave/exec/ToWave.cpp +++ b/velox/experimental/wave/exec/ToWave.cpp @@ -382,6 +382,7 @@ void CompileState::addFilterProject( auto filterProject = reinterpret_cast(op); outputType = driverFactory_.planNodes[nodeIndex]->outputType(); auto data = filterProject->exprsAndProjection(); + auto& identityProjections = filterProject->identityProjections(); int32_t firstProjection = 0; if (data.hasFilter) { addFilter(*data.exprs->exprs()[0], outputType); @@ -537,6 +538,7 @@ void CompileState::makeAggregateAccumulate(const core::AggregationNode* node) { nthContinuable_++, aggInstruction)); makeProject(numPrograms, node->outputType()); + auto project = reinterpret_cast(operators_.back().get()); for (auto i = 0; i < node->groupingKeys().size(); ++i) { std::string name = aggInstruction->keys[i]->label; operators_.back()->defined( diff --git a/velox/experimental/wave/exec/WaveDriver.cpp b/velox/experimental/wave/exec/WaveDriver.cpp index 81d07ffbe5e4..f49f12798927 100644 --- a/velox/experimental/wave/exec/WaveDriver.cpp +++ b/velox/experimental/wave/exec/WaveDriver.cpp @@ -189,6 +189,7 @@ WaveDriver::WaveDriver( states_(std::move(states)), instructionStatus_(instructionStatus) { VELOX_CHECK(!waveOperators.empty()); + auto returnBatchSize = 10000 * outputType_->size() * 10; deviceArena_ = std::make_unique( 100000000, getDeviceAllocator(getDevice()), 400000000); pipelines_.emplace_back(); @@ -221,6 +222,7 @@ RowVectorPtr WaveDriver::getOutput() { return nullptr; } barrier_->enter(); + auto guard = [&]() { barrier_->leave(); }; startTimeMs_ = getCurrentTimeMs(); int32_t last = pipelines_.size() - 1; try { diff --git a/velox/expression/Expr.cpp b/velox/expression/Expr.cpp index 9e955a330bfb..d4d0404cea1b 100644 --- a/velox/expression/Expr.cpp +++ b/velox/expression/Expr.cpp @@ -993,7 +993,7 @@ Expr::PeelEncodingsResult Expr::peelEncodings( // its a shared subexpression. const auto& rowsToPeel = context.isFinalSelection() ? rows : *context.finalSelection(); - [[maybe_unused]] auto numFields = context.row()->childrenSize(); + auto numFields = context.row()->childrenSize(); std::vector vectorsToPeel; vectorsToPeel.reserve(distinctFields_.size()); for (auto* field : distinctFields_) { diff --git a/velox/expression/tests/ExprTest.cpp b/velox/expression/tests/ExprTest.cpp index d4d7577b48a8..507c75853f5d 100644 --- a/velox/expression/tests/ExprTest.cpp +++ b/velox/expression/tests/ExprTest.cpp @@ -4902,6 +4902,7 @@ TEST_F(ExprTest, disableMemoization) { makeIndices(2 * flatSize, [&](auto row) { return row % flatSize; }), 2 * flatSize, flatInput); + auto dictSize = dictInput->size(); auto inputRow = makeRowVector({dictInput}); auto exprSet = compileExpression("c0 + 1", asRowType(inputRow->type())); diff --git a/velox/expression/tests/GenericWriterTest.cpp b/velox/expression/tests/GenericWriterTest.cpp index fcf2f3e758be..9f016d0be875 100644 --- a/velox/expression/tests/GenericWriterTest.cpp +++ b/velox/expression/tests/GenericWriterTest.cpp @@ -212,9 +212,11 @@ TEST_F(GenericWriterTest, castToDifferentTypesNotSupported) { writer.init(*result); writer.setOffset(0); + auto& current1 = writer.current().castTo>(); writer.commit(false); writer.setOffset(1); + auto& current2 = writer.current().castTo>(); writer.commit(false); writer.setOffset(2); diff --git a/velox/expression/tests/MapWriterTest.cpp b/velox/expression/tests/MapWriterTest.cpp index 3394ed965687..0e543c2da41a 100644 --- a/velox/expression/tests/MapWriterTest.cpp +++ b/velox/expression/tests/MapWriterTest.cpp @@ -199,6 +199,7 @@ TEST_F(MapWriterTest, writeThenCommitNullNestedInRow) { { vectorWriter.setOffset(1); + auto& mapWriter = vectorWriter.current().get_writer_at<0>(); vectorWriter.commit(); } vectorWriter.finish(); diff --git a/velox/functions/lib/tests/KllSketchTest.cpp b/velox/functions/lib/tests/KllSketchTest.cpp index 3ce316c79d52..8023ccc53a4a 100644 --- a/velox/functions/lib/tests/KllSketchTest.cpp +++ b/velox/functions/lib/tests/KllSketchTest.cpp @@ -249,6 +249,7 @@ TEST_F(KllSketchTest, serialize) { } TEST_F(KllSketchTest, deserialize) { + constexpr int N = 1e5; constexpr int M = 1001; auto readFile = [](const std::string& path) { std::ifstream input(path); diff --git a/velox/functions/prestosql/aggregates/tests/MapAggTest.cpp b/velox/functions/prestosql/aggregates/tests/MapAggTest.cpp index 43bfda4c931e..a5ef1813cac0 100644 --- a/velox/functions/prestosql/aggregates/tests/MapAggTest.cpp +++ b/velox/functions/prestosql/aggregates/tests/MapAggTest.cpp @@ -33,6 +33,8 @@ class MapAggTest : public AggregationTestBase { }; TEST_F(MapAggTest, groupBy) { + vector_size_t num = 10; + auto data = makeRowVector({ makeFlatVector({0, 0, 0, 1, 1, 1, 2, 2, 2, 3}), makeFlatVector({0, 1, 2, 3, 4, 5, 6, 7, 8, 9}), @@ -72,6 +74,8 @@ TEST_F(MapAggTest, groupBy) { // Verify that null keys are skipped. TEST_F(MapAggTest, groupByNullKeys) { + vector_size_t num = 10; + auto data = makeRowVector({ makeFlatVector({0, 0, 0, 1, 1, 1, 2, 2, 2, 3}), makeNullableFlatVector( diff --git a/velox/functions/prestosql/benchmarks/DateTimeBenchmark.cpp b/velox/functions/prestosql/benchmarks/DateTimeBenchmark.cpp index 70d83fd357bc..10fb319dcd65 100644 --- a/velox/functions/prestosql/benchmarks/DateTimeBenchmark.cpp +++ b/velox/functions/prestosql/benchmarks/DateTimeBenchmark.cpp @@ -98,6 +98,7 @@ class DateTimeBenchmark : public functions::test::FunctionBenchmarkBase { void run(const std::string& functionName) { folly::BenchmarkSuspender suspender; + constexpr vector_size_t size = 10'000; VectorFuzzer::Options opts; opts.vectorSize = 10'000; diff --git a/velox/functions/prestosql/benchmarks/GenericBenchmark.cpp b/velox/functions/prestosql/benchmarks/GenericBenchmark.cpp index 238b60c22c8b..176c7d04f467 100644 --- a/velox/functions/prestosql/benchmarks/GenericBenchmark.cpp +++ b/velox/functions/prestosql/benchmarks/GenericBenchmark.cpp @@ -120,6 +120,9 @@ int main(int argc, char** argv) { facebook::velox::registerFunction>( {"typed_sum"}); + auto* pool = benchmarkBuilder.pool(); + auto& vm = benchmarkBuilder.vectorMaker(); + benchmarkBuilder .addBenchmarkSet( fmt::format("array_sum"), diff --git a/velox/functions/prestosql/benchmarks/RegexpReplaceBenchmark.cpp b/velox/functions/prestosql/benchmarks/RegexpReplaceBenchmark.cpp index 9cbc2a5663a5..447db31ea1e8 100644 --- a/velox/functions/prestosql/benchmarks/RegexpReplaceBenchmark.cpp +++ b/velox/functions/prestosql/benchmarks/RegexpReplaceBenchmark.cpp @@ -38,6 +38,9 @@ int main(int argc, char** argv) { options.vectorSize = 1'000; options.nullRatio = 0.01; + auto* pool = benchmarkBuilder.pool(); + auto& vm = benchmarkBuilder.vectorMaker(); + // Compare regexp_replace with fixed and lambda replacement. benchmarkBuilder.addBenchmarkSet("lambda_one_group", ROW({"c0"}, {VARCHAR()})) .withFuzzerOptions(options) diff --git a/velox/functions/prestosql/tests/BinaryFunctionsTest.cpp b/velox/functions/prestosql/tests/BinaryFunctionsTest.cpp index a1582e9f5eb0..18fb0b8b9a10 100644 --- a/velox/functions/prestosql/tests/BinaryFunctionsTest.cpp +++ b/velox/functions/prestosql/tests/BinaryFunctionsTest.cpp @@ -300,6 +300,13 @@ TEST_F(BinaryFunctionsTest, xxhash64) { return evaluateOnce("xxhash64(c0)", VARBINARY(), value); }; + const auto toVarbinary = [](const int64_t input) { + std::string out; + out.resize(sizeof(input)); + std::memcpy(out.data(), &input, sizeof(input)); + return out; + }; + EXPECT_EQ(hexToDec("EF46DB3751D8E999"), xxhash64("")); EXPECT_EQ(std::nullopt, xxhash64(std::nullopt)); diff --git a/velox/functions/prestosql/types/IPAddressType.cpp b/velox/functions/prestosql/types/IPAddressType.cpp index aebf83f0d615..d9569c01f7a9 100644 --- a/velox/functions/prestosql/types/IPAddressType.cpp +++ b/velox/functions/prestosql/types/IPAddressType.cpp @@ -113,6 +113,7 @@ class IPAddressCastOperator : public exec::CastOperator { BaseVector& result) { auto* flatResult = result.as>(); const auto* ipAddressStrings = input.as>(); + int128_t intAddr; context.applyToSelectedNoThrow(rows, [&](auto row) { const auto ipAddressString = ipAddressStrings->valueAt(row); diff --git a/velox/serializers/tests/SerializerBenchmark.cpp b/velox/serializers/tests/SerializerBenchmark.cpp index e27fc7bc2556..a080a65f9fed 100644 --- a/velox/serializers/tests/SerializerBenchmark.cpp +++ b/velox/serializers/tests/SerializerBenchmark.cpp @@ -136,6 +136,7 @@ class SerializerBenchmark : public VectorTestBase { for (auto bits : bitsValues) { for (auto nullIdx = 0; nullIdx < nullPctValues.size(); ++nullIdx) { for (auto selIdx = 0; selIdx < numSelectedValues.size(); ++selIdx) { + int32_t numRepeat = 10 / numSelectedValues[selIdx]; cases.push_back(runCase(nullIdx, selIdx, bits)); } } diff --git a/velox/substrait/SubstraitToVeloxPlan.cpp b/velox/substrait/SubstraitToVeloxPlan.cpp index f13f4bc9bd82..295335e28c2e 100644 --- a/velox/substrait/SubstraitToVeloxPlan.cpp +++ b/velox/substrait/SubstraitToVeloxPlan.cpp @@ -545,6 +545,7 @@ core::PlanNodePtr SubstraitVeloxPlanConverter::toVeloxPlan( core::PlanNodePtr SubstraitVeloxPlanConverter::toVeloxPlan( const ::substrait::RelRoot& root) { // TODO: Use the names as the output names for the whole computing. + const auto& names = root.names(); if (root.has_input()) { const auto& rel = root.input(); return toVeloxPlan(rel); diff --git a/velox/type/tests/FilterTest.cpp b/velox/type/tests/FilterTest.cpp index a51305449629..765fab5d0478 100644 --- a/velox/type/tests/FilterTest.cpp +++ b/velox/type/tests/FilterTest.cpp @@ -1748,6 +1748,7 @@ TEST(FilterTest, mergeWithBytesMultiRange) { TEST(FilterTest, hugeIntRange) { auto filter = equalHugeint(HugeInt::build(1, 1), false); + auto testInt128 = [&](int128_t x) { return filter->testInt128(x); }; auto max = DecimalUtil::kLongDecimalMax; auto min = DecimalUtil::kLongDecimalMin; diff --git a/velox/vector/DecodedVector.cpp b/velox/vector/DecodedVector.cpp index 4c9c570572a7..fbea39d871b2 100644 --- a/velox/vector/DecodedVector.cpp +++ b/velox/vector/DecodedVector.cpp @@ -442,7 +442,7 @@ const uint64_t* DecodedVector::nulls(const SelectivityVector* rows) { // end but not greater. VELOX_CHECK_LE(rows->end(), size_); } - VELOX_DEBUG_ONLY const auto baseSize = baseVector_->size(); + auto baseSize = baseVector_->size(); applyToRows(rows, [&](auto i) { VELOX_DCHECK_LT(indices_[i], baseSize); bits::setNull(rawCopiedNulls, i, bits::isBitNull(nulls_, indices_[i])); diff --git a/velox/vector/tests/VectorCompareTest.cpp b/velox/vector/tests/VectorCompareTest.cpp index 1dc7fb82fa67..7a30de340c1b 100644 --- a/velox/vector/tests/VectorCompareTest.cpp +++ b/velox/vector/tests/VectorCompareTest.cpp @@ -309,6 +309,9 @@ TEST_F(VectorCompareTest, compareNullAsIndeterminateSimpleOfComplex) { // Test equality with nulls. { + CompareFlags equalityFlags = CompareFlags::equality( + CompareFlags::NullHandlingMode::kNullAsIndeterminate); + // Constat vector. testCompare( constantVectorNull, 0, constantVectorOne, 1, kEquality, kIndeterminate); diff --git a/velox/vector/tests/VectorTest.cpp b/velox/vector/tests/VectorTest.cpp index add1aa8b03c1..fc4f1e92ff1c 100644 --- a/velox/vector/tests/VectorTest.cpp +++ b/velox/vector/tests/VectorTest.cpp @@ -164,6 +164,7 @@ class VectorTest : public testing::Test, public velox::test::VectorTestBase { BufferPtr nulls; if (withNulls) { nulls = allocateNulls(numRows, pool()); + int32_t childCounter = 0; auto rawNulls = nulls->asMutable(); for (int32_t i = 0; i < numRows; ++i) { bits::setNull(rawNulls, i, i % 8 == 0);