139 lines
5.1 KiB
C++
139 lines
5.1 KiB
C++
|
//===- llvm/unittest/XRay/FDRBlockVerifierTest.cpp --------------*- C++ -*-===//
|
||
|
//
|
||
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
||
|
// See https://llvm.org/LICENSE.txt for license information.
|
||
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
#include "llvm/Testing/Support/Error.h"
|
||
|
#include "llvm/XRay/BlockIndexer.h"
|
||
|
#include "llvm/XRay/BlockVerifier.h"
|
||
|
#include "llvm/XRay/FDRLogBuilder.h"
|
||
|
#include "llvm/XRay/FDRRecords.h"
|
||
|
#include "gmock/gmock.h"
|
||
|
#include "gtest/gtest.h"
|
||
|
|
||
|
namespace llvm {
|
||
|
namespace xray {
|
||
|
namespace {
|
||
|
|
||
|
using ::testing::ElementsAre;
|
||
|
using ::testing::Not;
|
||
|
using ::testing::SizeIs;
|
||
|
|
||
|
TEST(FDRBlockVerifierTest, ValidBlocksV3) {
|
||
|
auto Block0 = LogBuilder()
|
||
|
.add<BufferExtents>(80)
|
||
|
.add<NewBufferRecord>(1)
|
||
|
.add<WallclockRecord>(1, 2)
|
||
|
.add<PIDRecord>(1)
|
||
|
.add<NewCPUIDRecord>(1, 2)
|
||
|
.add<FunctionRecord>(RecordTypes::ENTER, 1, 1)
|
||
|
.add<FunctionRecord>(RecordTypes::EXIT, 1, 100)
|
||
|
.consume();
|
||
|
auto Block1 = LogBuilder()
|
||
|
.add<BufferExtents>(80)
|
||
|
.add<NewBufferRecord>(1)
|
||
|
.add<WallclockRecord>(1, 2)
|
||
|
.add<PIDRecord>(1)
|
||
|
.add<NewCPUIDRecord>(1, 2)
|
||
|
.add<FunctionRecord>(RecordTypes::ENTER, 1, 1)
|
||
|
.add<FunctionRecord>(RecordTypes::EXIT, 1, 100)
|
||
|
.consume();
|
||
|
auto Block2 = LogBuilder()
|
||
|
.add<BufferExtents>(80)
|
||
|
.add<NewBufferRecord>(2)
|
||
|
.add<WallclockRecord>(1, 2)
|
||
|
.add<PIDRecord>(1)
|
||
|
.add<NewCPUIDRecord>(2, 2)
|
||
|
.add<FunctionRecord>(RecordTypes::ENTER, 1, 1)
|
||
|
.add<FunctionRecord>(RecordTypes::EXIT, 1, 100)
|
||
|
.consume();
|
||
|
BlockIndexer::Index Index;
|
||
|
BlockIndexer Indexer(Index);
|
||
|
for (auto B : {std::ref(Block0), std::ref(Block1), std::ref(Block2)}) {
|
||
|
for (auto &R : B.get())
|
||
|
ASSERT_FALSE(errorToBool(R->apply(Indexer)));
|
||
|
ASSERT_FALSE(errorToBool(Indexer.flush()));
|
||
|
}
|
||
|
|
||
|
BlockVerifier Verifier;
|
||
|
for (auto &ProcessThreadBlocks : Index) {
|
||
|
auto &Blocks = ProcessThreadBlocks.second;
|
||
|
for (auto &B : Blocks) {
|
||
|
for (auto *R : B.Records)
|
||
|
ASSERT_FALSE(errorToBool(R->apply(Verifier)));
|
||
|
ASSERT_FALSE(errorToBool(Verifier.verify()));
|
||
|
Verifier.reset();
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
TEST(FDRBlockVerifierTest, MissingPIDRecord) {
|
||
|
auto Block = LogBuilder()
|
||
|
.add<BufferExtents>(20)
|
||
|
.add<NewBufferRecord>(1)
|
||
|
.add<WallclockRecord>(1, 2)
|
||
|
.add<NewCPUIDRecord>(1, 2)
|
||
|
.add<FunctionRecord>(RecordTypes::ENTER, 1, 1)
|
||
|
.add<FunctionRecord>(RecordTypes::EXIT, 1, 100)
|
||
|
.consume();
|
||
|
BlockVerifier Verifier;
|
||
|
for (auto &R : Block)
|
||
|
ASSERT_FALSE(errorToBool(R->apply(Verifier)));
|
||
|
ASSERT_FALSE(errorToBool(Verifier.verify()));
|
||
|
}
|
||
|
|
||
|
TEST(FDRBlockVerifierTest, MissingBufferExtents) {
|
||
|
auto Block = LogBuilder()
|
||
|
.add<NewBufferRecord>(1)
|
||
|
.add<WallclockRecord>(1, 2)
|
||
|
.add<NewCPUIDRecord>(1, 2)
|
||
|
.add<FunctionRecord>(RecordTypes::ENTER, 1, 1)
|
||
|
.add<FunctionRecord>(RecordTypes::EXIT, 1, 100)
|
||
|
.consume();
|
||
|
BlockVerifier Verifier;
|
||
|
for (auto &R : Block)
|
||
|
ASSERT_FALSE(errorToBool(R->apply(Verifier)));
|
||
|
ASSERT_FALSE(errorToBool(Verifier.verify()));
|
||
|
}
|
||
|
|
||
|
TEST(FDRBlockVerifierTest, IgnoreRecordsAfterEOB) {
|
||
|
auto Block = LogBuilder()
|
||
|
.add<NewBufferRecord>(1)
|
||
|
.add<WallclockRecord>(1, 2)
|
||
|
.add<NewCPUIDRecord>(1, 2)
|
||
|
.add<EndBufferRecord>()
|
||
|
.add<FunctionRecord>(RecordTypes::ENTER, 1, 1)
|
||
|
.add<FunctionRecord>(RecordTypes::EXIT, 1, 100)
|
||
|
.consume();
|
||
|
BlockVerifier Verifier;
|
||
|
for (auto &R : Block)
|
||
|
ASSERT_FALSE(errorToBool(R->apply(Verifier)));
|
||
|
ASSERT_FALSE(errorToBool(Verifier.verify()));
|
||
|
}
|
||
|
|
||
|
TEST(FDRBlockVerifierTest, MalformedV2) {
|
||
|
auto Block = LogBuilder()
|
||
|
.add<NewBufferRecord>(1)
|
||
|
.add<WallclockRecord>(1, 2)
|
||
|
.add<NewCPUIDRecord>(1, 2)
|
||
|
.add<FunctionRecord>(RecordTypes::ENTER, 1, 1)
|
||
|
.add<FunctionRecord>(RecordTypes::EXIT, 1, 100)
|
||
|
.add<NewBufferRecord>(2)
|
||
|
.consume();
|
||
|
BlockVerifier Verifier;
|
||
|
|
||
|
ASSERT_THAT(Block, SizeIs(6u));
|
||
|
EXPECT_THAT_ERROR(Block[0]->apply(Verifier), Succeeded());
|
||
|
EXPECT_THAT_ERROR(Block[1]->apply(Verifier), Succeeded());
|
||
|
EXPECT_THAT_ERROR(Block[2]->apply(Verifier), Succeeded());
|
||
|
EXPECT_THAT_ERROR(Block[3]->apply(Verifier), Succeeded());
|
||
|
EXPECT_THAT_ERROR(Block[4]->apply(Verifier), Succeeded());
|
||
|
EXPECT_THAT_ERROR(Block[5]->apply(Verifier), Failed());
|
||
|
}
|
||
|
|
||
|
} // namespace
|
||
|
} // namespace xray
|
||
|
} // namespace llvm
|