From 61f48ca35e0bc16f41443beb60d38dea181a25a9 Mon Sep 17 00:00:00 2001 From: Marcello Maggioni Date: Thu, 10 Aug 2017 15:35:25 +0000 Subject: [PATCH] [unittests] Adding a unittest for ChangeTaTargetIndex. NFC Differential Revision: https://reviews.llvm.org/D36565 llvm-svn: 310610 --- llvm/unittests/CodeGen/CMakeLists.txt | 1 + llvm/unittests/CodeGen/MachineOperandTest.cpp | 40 +++++++++++++++++++ 2 files changed, 41 insertions(+) create mode 100644 llvm/unittests/CodeGen/MachineOperandTest.cpp diff --git a/llvm/unittests/CodeGen/CMakeLists.txt b/llvm/unittests/CodeGen/CMakeLists.txt index e944f6c9e3b9..8ee714dc78ff 100644 --- a/llvm/unittests/CodeGen/CMakeLists.txt +++ b/llvm/unittests/CodeGen/CMakeLists.txt @@ -9,6 +9,7 @@ set(CodeGenSources DIEHashTest.cpp LowLevelTypeTest.cpp MachineInstrBundleIteratorTest.cpp + MachineOperandTest.cpp ScalableVectorMVTsTest.cpp ) diff --git a/llvm/unittests/CodeGen/MachineOperandTest.cpp b/llvm/unittests/CodeGen/MachineOperandTest.cpp new file mode 100644 index 000000000000..afbf4f4c3689 --- /dev/null +++ b/llvm/unittests/CodeGen/MachineOperandTest.cpp @@ -0,0 +1,40 @@ +//===- MachineOperandTest.cpp ---------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#include "llvm/ADT/ilist_node.h" +#include "llvm/CodeGen/MachineOperand.h" +#include "gtest/gtest.h" + +using namespace llvm; + +namespace { + +TEST(MachineOperandTest, ChangeToTargetIndexTest) { + // Creating a MachineOperand to change it to TargetIndex + MachineOperand MO = MachineOperand::CreateImm(50); + + // Checking some precondition on the newly created + // MachineOperand. + ASSERT_TRUE(MO.isImm()); + ASSERT_TRUE(MO.getImm() == 50); + ASSERT_FALSE(MO.isTargetIndex()); + + // Changing to TargetIndex with some arbitrary values + // for index, offset and flags. + MO.ChangeToTargetIndex(74, 57, 12); + + // Checking that the mutation to TargetIndex happened + // correctly. + ASSERT_TRUE(MO.isTargetIndex()); + ASSERT_TRUE(MO.getIndex() == 74); + ASSERT_TRUE(MO.getOffset() == 57); + ASSERT_TRUE(MO.getTargetFlags() == 12); +} + +} // end namespace