/* -*- mode: c++ -*- * Copyright (C) 2020 Eric Paniagua (epaniagua@google.com) * * This program is free software: you can redistribute it and/or modify it under * the terms of the GNU General Public License as published by the Free Software * Foundation, version 3. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License along with * this program. If not, see . */ #pragma once #include #include "testing/common/Simulator.h" #include "testing/common/State.h" // Out of order because `fix-macros.h` clears the preprocessor environment for // gtest and gmock. #include "testing/common/fix-macros.h" #include "gtest/gtest.h" namespace kaleidoscope { namespace testing { class VirtualDeviceTest : public ::testing::Test { protected: void RunCycle(); void RunCycles(size_t n); const State& Result() const; ::kaleidoscope::testing::Simulator sim_; private: State state_; }; } // namespace testing } // namespace kaleidoscope