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