#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()); }