forked from OSchip/llvm-project
Add a unittests directory for MLIR and start adding tests for OperandStorage from InstructionSupport.h.
PiperOrigin-RevId: 236911640
This commit is contained in:
parent
89d42f15a7
commit
7b0b344c5e
|
@ -0,0 +1,117 @@
|
|||
//===- InstructionSupportTest.cpp - Instruction support unit tests --------===//
|
||||
//
|
||||
// Copyright 2019 The MLIR Authors.
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
// =============================================================================
|
||||
|
||||
#include "mlir/IR/InstructionSupport.h"
|
||||
#include "mlir/IR/Builders.h"
|
||||
#include "mlir/IR/StandardTypes.h"
|
||||
#include "gtest/gtest.h"
|
||||
|
||||
using namespace mlir;
|
||||
using namespace mlir::detail;
|
||||
|
||||
namespace {
|
||||
Instruction *createInst(MLIRContext *context, bool resizableOperands,
|
||||
ArrayRef<Value *> operands = llvm::None,
|
||||
ArrayRef<Type> resultTypes = llvm::None) {
|
||||
return Instruction::create(
|
||||
UnknownLoc::get(context), OperationName("foo.bar", context), operands,
|
||||
resultTypes, llvm::None, llvm::None, 0, resizableOperands, context);
|
||||
}
|
||||
|
||||
TEST(OperandStorageTest, NonResizable) {
|
||||
MLIRContext context;
|
||||
Builder builder(&context);
|
||||
|
||||
Instruction *useInst =
|
||||
createInst(&context, /*resizableOperands=*/false, /*operands=*/llvm::None,
|
||||
builder.getIntegerType(16));
|
||||
Value *operand = useInst->getResult(0);
|
||||
|
||||
// Create a non-resizable instruction with one operand.
|
||||
Instruction *user = createInst(&context, /*resizableOperands=*/false, operand,
|
||||
builder.getIntegerType(16));
|
||||
|
||||
// Sanity check the storage.
|
||||
EXPECT_EQ(user->hasResizableOperandsList(), false);
|
||||
|
||||
// The same number of operands is okay.
|
||||
user->setOperands(operand);
|
||||
EXPECT_EQ(user->getNumOperands(), 1);
|
||||
|
||||
// Removing is okay.
|
||||
user->setOperands(llvm::None);
|
||||
EXPECT_EQ(user->getNumOperands(), 0);
|
||||
|
||||
// Destroy the instructions.
|
||||
user->destroy();
|
||||
useInst->destroy();
|
||||
}
|
||||
|
||||
TEST(OperandStorageDeathTest, AddToNonResizable) {
|
||||
MLIRContext context;
|
||||
Builder builder(&context);
|
||||
|
||||
Instruction *useInst =
|
||||
createInst(&context, /*resizableOperands=*/false, /*operands=*/llvm::None,
|
||||
builder.getIntegerType(16));
|
||||
Value *operand = useInst->getResult(0);
|
||||
|
||||
// Create a non-resizable instruction with one operand.
|
||||
Instruction *user = createInst(&context, /*resizableOperands=*/false, operand,
|
||||
builder.getIntegerType(16));
|
||||
|
||||
// Sanity check the storage.
|
||||
EXPECT_EQ(user->hasResizableOperandsList(), false);
|
||||
|
||||
// Adding operands to a non resizable instruction should result in a failure.
|
||||
ASSERT_DEATH(user->setOperands({operand, operand}), "");
|
||||
}
|
||||
|
||||
TEST(OperandStorageTest, Resizable) {
|
||||
MLIRContext context;
|
||||
Builder builder(&context);
|
||||
|
||||
Instruction *useInst =
|
||||
createInst(&context, /*resizableOperands=*/false, /*operands=*/llvm::None,
|
||||
builder.getIntegerType(16));
|
||||
Value *operand = useInst->getResult(0);
|
||||
|
||||
// Create a resizable instruction with one operand.
|
||||
Instruction *user = createInst(&context, /*resizableOperands=*/true, operand,
|
||||
builder.getIntegerType(16));
|
||||
|
||||
// Sanity check the storage.
|
||||
EXPECT_EQ(user->hasResizableOperandsList(), true);
|
||||
|
||||
// The same number of operands is okay.
|
||||
user->setOperands(operand);
|
||||
EXPECT_EQ(user->getNumOperands(), 1);
|
||||
|
||||
// Removing is okay.
|
||||
user->setOperands(llvm::None);
|
||||
EXPECT_EQ(user->getNumOperands(), 0);
|
||||
|
||||
// Adding more operands is okay.
|
||||
user->setOperands({operand, operand, operand});
|
||||
EXPECT_EQ(user->getNumOperands(), 3);
|
||||
|
||||
// Destroy the instructions.
|
||||
user->destroy();
|
||||
useInst->destroy();
|
||||
}
|
||||
|
||||
} // end namespace
|
Loading…
Reference in New Issue