1*84e80979SFrancis Visoiu Mistrih //===- unittest/Support/BitstreamRemarksFormatTest.cpp - BitCodes tests ---===//
2*84e80979SFrancis Visoiu Mistrih //
3*84e80979SFrancis Visoiu Mistrih // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*84e80979SFrancis Visoiu Mistrih // See https://llvm.org/LICENSE.txt for license information.
5*84e80979SFrancis Visoiu Mistrih // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*84e80979SFrancis Visoiu Mistrih //
7*84e80979SFrancis Visoiu Mistrih //===----------------------------------------------------------------------===//
8*84e80979SFrancis Visoiu Mistrih
9*84e80979SFrancis Visoiu Mistrih #include "llvm/Remarks/BitstreamRemarkContainer.h"
10*84e80979SFrancis Visoiu Mistrih #include "gtest/gtest.h"
11*84e80979SFrancis Visoiu Mistrih
12*84e80979SFrancis Visoiu Mistrih using namespace llvm;
13*84e80979SFrancis Visoiu Mistrih
14*84e80979SFrancis Visoiu Mistrih // The goal for this test is to observe test failures and carefully update the
15*84e80979SFrancis Visoiu Mistrih // constants when they change.
16*84e80979SFrancis Visoiu Mistrih
17*84e80979SFrancis Visoiu Mistrih // This should not change over time.
TEST(BitstreamRemarksFormat,Magic)18*84e80979SFrancis Visoiu Mistrih TEST(BitstreamRemarksFormat, Magic) {
19*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::ContainerMagic, "RMRK");
20*84e80979SFrancis Visoiu Mistrih }
21*84e80979SFrancis Visoiu Mistrih
22*84e80979SFrancis Visoiu Mistrih // This should be updated whenever any of the tests below are modified.
TEST(BitstreamRemarksFormat,ContainerVersion)23*84e80979SFrancis Visoiu Mistrih TEST(BitstreamRemarksFormat, ContainerVersion) {
24*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::CurrentContainerVersion, 0UL);
25*84e80979SFrancis Visoiu Mistrih }
26*84e80979SFrancis Visoiu Mistrih
27*84e80979SFrancis Visoiu Mistrih // The values of the current blocks should not change over time.
28*84e80979SFrancis Visoiu Mistrih // When adding new blocks, make sure to append them to the enum.
TEST(BitstreamRemarksFormat,BlockIDs)29*84e80979SFrancis Visoiu Mistrih TEST(BitstreamRemarksFormat, BlockIDs) {
30*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::META_BLOCK_ID, 8);
31*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::REMARK_BLOCK_ID, 9);
32*84e80979SFrancis Visoiu Mistrih }
33*84e80979SFrancis Visoiu Mistrih
34*84e80979SFrancis Visoiu Mistrih // The values of the current records should not change over time.
35*84e80979SFrancis Visoiu Mistrih // When adding new records, make sure to append them to the enum.
TEST(BitstreamRemarksFormat,RecordIDs)36*84e80979SFrancis Visoiu Mistrih TEST(BitstreamRemarksFormat, RecordIDs) {
37*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::RECORD_FIRST, 1);
38*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::RECORD_META_CONTAINER_INFO, 1);
39*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::RECORD_META_REMARK_VERSION, 2);
40*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::RECORD_META_STRTAB, 3);
41*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::RECORD_META_EXTERNAL_FILE, 4);
42*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::RECORD_REMARK_HEADER, 5);
43*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::RECORD_REMARK_DEBUG_LOC, 6);
44*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::RECORD_REMARK_HOTNESS, 7);
45*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::RECORD_REMARK_ARG_WITH_DEBUGLOC, 8);
46*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::RECORD_REMARK_ARG_WITHOUT_DEBUGLOC, 9);
47*84e80979SFrancis Visoiu Mistrih EXPECT_EQ(remarks::RECORD_LAST, 9);
48*84e80979SFrancis Visoiu Mistrih }
49