// Copyright 2022 The Tint 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. #ifndef SRC_TINT_IR_TEST_HELPER_H_ #define SRC_TINT_IR_TEST_HELPER_H_ #include #include #include "gtest/gtest.h" #include "src/tint/ir/builder_impl.h" #include "src/tint/ir/disassembler.h" #include "src/tint/program_builder.h" namespace tint::ir { /// Helper class for testing template class TestHelperBase : public BASE, public ProgramBuilder { public: TestHelperBase() = default; ~TestHelperBase() override = default; /// Builds and returns a BuilderImpl from the program. /// @note The builder is only created once. Multiple calls to Build() will /// return the same builder without rebuilding. /// @return the builder BuilderImpl& CreateBuilder() { if (gen_) { return *gen_; } program = std::make_unique(std::move(*this)); diag::Formatter formatter; [&]() { ASSERT_TRUE(program->IsValid()) << formatter.format(program->Diagnostics()); }(); gen_ = std::make_unique(program.get()); return *gen_; } /// Creates a BuilderImpl without an originating program. This is used for testing the /// expressions which don't require the full builder implementation. The current flow block /// is initialized with an empty block. /// @returns the BuilderImpl for testing. BuilderImpl& CreateEmptyBuilder() { gen_ = std::make_unique(nullptr); gen_->current_flow_block = gen_->builder.CreateBlock(); return *gen_; } /// The program built with a call to Build() std::unique_ptr program; private: std::unique_ptr gen_; }; using TestHelper = TestHelperBase; template using TestParamHelper = TestHelperBase>; } // namespace tint::ir #endif // SRC_TINT_IR_TEST_HELPER_H_