diff options
author | Dimitry Andric <dim@FreeBSD.org> | 2019-12-20 19:53:05 +0000 |
---|---|---|
committer | Dimitry Andric <dim@FreeBSD.org> | 2019-12-20 19:53:05 +0000 |
commit | 0b57cec536236d46e3dba9bd041533462f33dbb7 (patch) | |
tree | 56229dbdbbf76d18580f72f789003db17246c8d9 /contrib/llvm-project/llvm/lib/Testing | |
parent | 718ef55ec7785aae63f98f8ca05dc07ed399c16d (diff) |
Notes
Diffstat (limited to 'contrib/llvm-project/llvm/lib/Testing')
3 files changed, 170 insertions, 0 deletions
diff --git a/contrib/llvm-project/llvm/lib/Testing/Support/Annotations.cpp b/contrib/llvm-project/llvm/lib/Testing/Support/Annotations.cpp new file mode 100644 index 000000000000..09c572011d36 --- /dev/null +++ b/contrib/llvm-project/llvm/lib/Testing/Support/Annotations.cpp @@ -0,0 +1,95 @@ +//===--- Annotations.cpp - Annotated source code for unit tests --*- 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/Annotations.h" + +#include "llvm/ADT/StringExtras.h" +#include "llvm/Support/FormatVariadic.h" +#include "llvm/Support/raw_ostream.h" + +using namespace llvm; + +// Crash if the assertion fails, printing the message and testcase. +// More elegant error handling isn't needed for unit tests. +static void require(bool Assertion, const char *Msg, llvm::StringRef Code) { + if (!Assertion) { + llvm::errs() << "Annotated testcase: " << Msg << "\n" << Code << "\n"; + llvm_unreachable("Annotated testcase assertion failed!"); + } +} + +Annotations::Annotations(llvm::StringRef Text) { + auto Require = [Text](bool Assertion, const char *Msg) { + require(Assertion, Msg, Text); + }; + llvm::Optional<llvm::StringRef> Name; + llvm::SmallVector<std::pair<llvm::StringRef, size_t>, 8> OpenRanges; + + Code.reserve(Text.size()); + while (!Text.empty()) { + if (Text.consume_front("^")) { + Points[Name.getValueOr("")].push_back(Code.size()); + Name = llvm::None; + continue; + } + if (Text.consume_front("[[")) { + OpenRanges.emplace_back(Name.getValueOr(""), Code.size()); + Name = llvm::None; + continue; + } + Require(!Name, "$name should be followed by ^ or [["); + if (Text.consume_front("]]")) { + Require(!OpenRanges.empty(), "unmatched ]]"); + Range R; + R.Begin = OpenRanges.back().second; + R.End = Code.size(); + Ranges[OpenRanges.back().first].push_back(R); + OpenRanges.pop_back(); + continue; + } + if (Text.consume_front("$")) { + Name = Text.take_while(llvm::isAlnum); + Text = Text.drop_front(Name->size()); + continue; + } + Code.push_back(Text.front()); + Text = Text.drop_front(); + } + Require(!Name, "unterminated $name"); + Require(OpenRanges.empty(), "unmatched [["); +} + +size_t Annotations::point(llvm::StringRef Name) const { + auto I = Points.find(Name); + require(I != Points.end() && I->getValue().size() == 1, + "expected exactly one point", Code); + return I->getValue()[0]; +} + +std::vector<size_t> Annotations::points(llvm::StringRef Name) const { + auto P = Points.lookup(Name); + return {P.begin(), P.end()}; +} + +Annotations::Range Annotations::range(llvm::StringRef Name) const { + auto I = Ranges.find(Name); + require(I != Ranges.end() && I->getValue().size() == 1, + "expected exactly one range", Code); + return I->getValue()[0]; +} + +std::vector<Annotations::Range> +Annotations::ranges(llvm::StringRef Name) const { + auto R = Ranges.lookup(Name); + return {R.begin(), R.end()}; +} + +llvm::raw_ostream &llvm::operator<<(llvm::raw_ostream &O, + const llvm::Annotations::Range &R) { + return O << llvm::formatv("[{0}, {1})", R.Begin, R.End); +} diff --git a/contrib/llvm-project/llvm/lib/Testing/Support/Error.cpp b/contrib/llvm-project/llvm/lib/Testing/Support/Error.cpp new file mode 100644 index 000000000000..a5f8f9b47b3f --- /dev/null +++ b/contrib/llvm-project/llvm/lib/Testing/Support/Error.cpp @@ -0,0 +1,22 @@ +//===- llvm/Testing/Support/Error.cpp -------------------------------------===// +// +// 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/ADT/StringRef.h" + +using namespace llvm; + +llvm::detail::ErrorHolder llvm::detail::TakeError(llvm::Error Err) { + std::vector<std::shared_ptr<ErrorInfoBase>> Infos; + handleAllErrors(std::move(Err), + [&Infos](std::unique_ptr<ErrorInfoBase> Info) { + Infos.emplace_back(std::move(Info)); + }); + return {std::move(Infos)}; +} diff --git a/contrib/llvm-project/llvm/lib/Testing/Support/SupportHelpers.cpp b/contrib/llvm-project/llvm/lib/Testing/Support/SupportHelpers.cpp new file mode 100644 index 000000000000..5f53b2330b20 --- /dev/null +++ b/contrib/llvm-project/llvm/lib/Testing/Support/SupportHelpers.cpp @@ -0,0 +1,53 @@ + +#include "llvm/Testing/Support/SupportHelpers.h" + +#include "llvm/ADT/SmallString.h" +#include "llvm/ADT/Twine.h" +#include "llvm/Support/Error.h" +#include "llvm/Support/FileSystem.h" +#include "llvm/Support/MemoryBuffer.h" +#include "llvm/Support/Path.h" + +#include "gtest/gtest.h" + +using namespace llvm; +using namespace llvm::unittest; + +static std::pair<bool, SmallString<128>> findSrcDirMap(StringRef Argv0) { + SmallString<128> BaseDir = llvm::sys::path::parent_path(Argv0); + + llvm::sys::fs::make_absolute(BaseDir); + + SmallString<128> PathInSameDir = BaseDir; + llvm::sys::path::append(PathInSameDir, "llvm.srcdir.txt"); + + if (llvm::sys::fs::is_regular_file(PathInSameDir)) + return std::make_pair(true, std::move(PathInSameDir)); + + SmallString<128> PathInParentDir = llvm::sys::path::parent_path(BaseDir); + + llvm::sys::path::append(PathInParentDir, "llvm.srcdir.txt"); + if (llvm::sys::fs::is_regular_file(PathInParentDir)) + return std::make_pair(true, std::move(PathInParentDir)); + + return std::pair<bool, SmallString<128>>(false, {}); +} + +SmallString<128> llvm::unittest::getInputFileDirectory(const char *Argv0) { + bool Found = false; + SmallString<128> InputFilePath; + std::tie(Found, InputFilePath) = findSrcDirMap(Argv0); + + EXPECT_TRUE(Found) << "Unit test source directory file does not exist."; + + auto File = MemoryBuffer::getFile(InputFilePath); + + EXPECT_TRUE(static_cast<bool>(File)) + << "Could not open unit test source directory file."; + + InputFilePath.clear(); + InputFilePath.append((*File)->getBuffer().trim()); + llvm::sys::path::append(InputFilePath, "Inputs"); + llvm::sys::path::native(InputFilePath); + return InputFilePath; +} |