#include "gtest/gtest.h" #include "kompute/Kompute.hpp" TEST(TestOpTensorCreate, CreateSingleTensorSingleOp) { kp::Manager mgr; std::vector testVecA{ 9, 8, 7 }; std::shared_ptr tensorA{new kp::Tensor(testVecA)}; mgr.evalOpDefault({tensorA}); EXPECT_TRUE(tensorA->isInit()); EXPECT_EQ(tensorA->data(), testVecA); tensorA->freeMemoryDestroyGPUResources(); EXPECT_FALSE(tensorA->isInit()); } TEST(TestOpTensorCreate, CreateMultipleTensorSingleOp) { kp::Manager mgr; std::vector testVecA{ 9, 8, 7 }; std::vector testVecB{ 6, 5, 4 }; std::shared_ptr tensorA{new kp::Tensor(testVecA)}; std::shared_ptr tensorB{new kp::Tensor(testVecB)}; mgr.evalOpDefault({tensorA, tensorB}); EXPECT_TRUE(tensorA->isInit()); EXPECT_TRUE(tensorB->isInit()); EXPECT_EQ(tensorA->data(), testVecA); EXPECT_EQ(tensorB->data(), testVecB); } TEST(TestOpTensorCreate, CreateMultipleTensorMultipleOp) { kp::Manager mgr; std::vector testVecA{ 9, 8, 7 }; std::vector testVecB{ 6, 5, 4 }; std::shared_ptr tensorA{new kp::Tensor(testVecA)}; std::shared_ptr tensorB{new kp::Tensor(testVecB)}; mgr.evalOpDefault({tensorA}); mgr.evalOpDefault({tensorB}); EXPECT_TRUE(tensorA->isInit()); EXPECT_TRUE(tensorB->isInit()); EXPECT_EQ(tensorA->data(), testVecA); EXPECT_EQ(tensorB->data(), testVecB); } TEST(TestOpTensorCreate, ManageTensorMemoryWhenOpTensorCreateDestroyed) { std::vector testVecA{ 9, 8, 7 }; std::vector testVecB{ 6, 5, 4 }; std::shared_ptr tensorA{new kp::Tensor(testVecA)}; std::shared_ptr tensorB{new kp::Tensor(testVecB)}; { kp::Manager mgr; mgr.evalOpDefault({tensorA}); mgr.evalOpDefault({tensorB}); EXPECT_TRUE(tensorA->isInit()); EXPECT_TRUE(tensorB->isInit()); EXPECT_EQ(tensorA->data(), testVecA); EXPECT_EQ(tensorB->data(), testVecB); } EXPECT_FALSE(tensorA->isInit()); EXPECT_FALSE(tensorB->isInit()); } TEST(TestOpTensorCreate, NoErrorIfTensorFreedBefore) { std::vector testVecA{ 9, 8, 7 }; std::vector testVecB{ 6, 5, 4 }; std::shared_ptr tensorA{new kp::Tensor(testVecA)}; std::shared_ptr tensorB{new kp::Tensor(testVecB)}; kp::Manager mgr; mgr.evalOpDefault({tensorA}); mgr.evalOpDefault({tensorB}); EXPECT_TRUE(tensorA->isInit()); EXPECT_TRUE(tensorB->isInit()); EXPECT_EQ(tensorA->data(), testVecA); EXPECT_EQ(tensorB->data(), testVecB); tensorA->freeMemoryDestroyGPUResources(); tensorB->freeMemoryDestroyGPUResources(); EXPECT_FALSE(tensorA->isInit()); EXPECT_FALSE(tensorB->isInit()); }