mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-08 10:08:42 +08:00
166 lines
4.7 KiB
C++
166 lines
4.7 KiB
C++
////////////////////////////////////////////////////////////////////////////////
|
|
// Copyright 上海赜睿信息科技有限公司(Zilliz) - All Rights Reserved
|
|
// Unauthorized copying of this file, via any medium is strictly prohibited.
|
|
// Proprietary and confidential.
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
#include <gtest/gtest.h>
|
|
#include <thread>
|
|
#include <easylogging++.h>
|
|
#include <boost/filesystem.hpp>
|
|
|
|
#include "db/FaissExecutionEngine.h"
|
|
#include "db/Exception.h"
|
|
#include "db/Status.h"
|
|
#include "db/Options.h"
|
|
#include "db/DBMetaImpl.h"
|
|
#include "db/EngineFactory.h"
|
|
#include "db/Utils.h"
|
|
|
|
#include <vector>
|
|
|
|
using namespace zilliz::milvus;
|
|
|
|
namespace {
|
|
void CopyStatus(engine::Status& st1, engine::Status& st2) {
|
|
st1 = st2;
|
|
}
|
|
|
|
}
|
|
|
|
//TEST(DBMiscTest, ENGINE_API_TEST) {
|
|
// //engine api AddWithIdArray
|
|
// const uint16_t dim = 512;
|
|
// const long n = 10;
|
|
// engine::FaissExecutionEngine engine(512, "/tmp/1", "IDMap", "IDMap,Flat");
|
|
// std::vector<float> vectors;
|
|
// std::vector<long> ids;
|
|
// for (long i = 0; i < n; i++) {
|
|
// for (uint16_t k = 0; k < dim; k++) {
|
|
// vectors.push_back((float) k);
|
|
// }
|
|
// ids.push_back(i);
|
|
// }
|
|
//
|
|
// auto status = engine.AddWithIdArray(vectors, ids);
|
|
// ASSERT_TRUE(status.ok());
|
|
//
|
|
// auto engine_ptr = engine::EngineFactory::Build(128, "/tmp", engine::EngineType::INVALID);
|
|
// ASSERT_EQ(engine_ptr, nullptr);
|
|
//
|
|
// engine_ptr = engine::EngineFactory::Build(128, "/tmp", engine::EngineType::FAISS_IVFFLAT_GPU);
|
|
// ASSERT_NE(engine_ptr, nullptr);
|
|
//
|
|
// engine_ptr = engine::EngineFactory::Build(128, "/tmp", engine::EngineType::FAISS_IDMAP);
|
|
// ASSERT_NE(engine_ptr, nullptr);
|
|
//}
|
|
|
|
TEST(DBMiscTest, EXCEPTION_TEST) {
|
|
engine::Exception ex1("");
|
|
std::string what = ex1.what();
|
|
ASSERT_FALSE(what.empty());
|
|
|
|
engine::OutOfRangeException ex2;
|
|
what = ex2.what();
|
|
ASSERT_FALSE(what.empty());
|
|
}
|
|
|
|
TEST(DBMiscTest, STATUS_TEST) {
|
|
engine::Status status = engine::Status::OK();
|
|
std::string str = status.ToString();
|
|
ASSERT_FALSE(str.empty());
|
|
|
|
status = engine::Status::Error("wrong", "mistake");
|
|
ASSERT_TRUE(status.IsError());
|
|
str = status.ToString();
|
|
ASSERT_FALSE(str.empty());
|
|
|
|
status = engine::Status::NotFound("wrong", "mistake");
|
|
ASSERT_TRUE(status.IsNotFound());
|
|
str = status.ToString();
|
|
ASSERT_FALSE(str.empty());
|
|
|
|
status = engine::Status::DBTransactionError("wrong", "mistake");
|
|
ASSERT_TRUE(status.IsDBTransactionError());
|
|
str = status.ToString();
|
|
ASSERT_FALSE(str.empty());
|
|
|
|
engine::Status status_copy = engine::Status::OK();
|
|
CopyStatus(status_copy, status);
|
|
ASSERT_TRUE(status.IsDBTransactionError());
|
|
}
|
|
|
|
TEST(DBMiscTest, OPTIONS_TEST) {
|
|
try {
|
|
engine::ArchiveConf archive("$$##");
|
|
} catch (std::exception& ex) {
|
|
ASSERT_TRUE(true);
|
|
}
|
|
|
|
{
|
|
engine::ArchiveConf archive("delete", "no");
|
|
ASSERT_TRUE(archive.GetCriterias().empty());
|
|
}
|
|
|
|
{
|
|
engine::ArchiveConf archive("delete", "1:2");
|
|
ASSERT_TRUE(archive.GetCriterias().empty());
|
|
}
|
|
|
|
{
|
|
engine::ArchiveConf archive("delete", "1:2:3");
|
|
ASSERT_TRUE(archive.GetCriterias().empty());
|
|
}
|
|
|
|
{
|
|
engine::ArchiveConf archive("delete");
|
|
engine::ArchiveConf::CriteriaT criterial = {
|
|
{"disk", 1024},
|
|
{"days", 100}
|
|
};
|
|
archive.SetCriterias(criterial);
|
|
|
|
auto crit = archive.GetCriterias();
|
|
ASSERT_EQ(criterial["disk"], 1024);
|
|
ASSERT_EQ(criterial["days"], 100);
|
|
}
|
|
}
|
|
|
|
TEST(DBMiscTest, META_TEST) {
|
|
engine::DBMetaOptions options;
|
|
options.path = "/tmp/milvus_test";
|
|
engine::meta::DBMetaImpl impl(options);
|
|
|
|
time_t tt;
|
|
time( &tt );
|
|
int delta = 10;
|
|
engine::meta::DateT dt = impl.GetDate(tt, delta);
|
|
ASSERT_GT(dt, 0);
|
|
}
|
|
|
|
TEST(DBMiscTest, UTILS_TEST) {
|
|
engine::DBMetaOptions options;
|
|
options.path = "/tmp/milvus_test/main";
|
|
options.slave_paths.push_back("/tmp/milvus_test/slave_1");
|
|
options.slave_paths.push_back("/tmp/milvus_test/slave_2");
|
|
|
|
const std::string TABLE_NAME = "test_tbl";
|
|
auto status = engine::utils::CreateTablePath(options, TABLE_NAME);
|
|
ASSERT_TRUE(status.ok());
|
|
ASSERT_TRUE(boost::filesystem::exists(options.path));
|
|
for(auto& path : options.slave_paths) {
|
|
ASSERT_TRUE(boost::filesystem::exists(path));
|
|
}
|
|
|
|
engine::meta::TableFileSchema file;
|
|
file.id_ = 50;
|
|
file.table_id_ = TABLE_NAME;
|
|
file.file_type_ = 3;
|
|
file.date_ = 155000;
|
|
status = engine::utils::GetTableFilePath(options, file);
|
|
ASSERT_FALSE(status.ok());
|
|
ASSERT_TRUE(file.location_.empty());
|
|
|
|
status = engine::utils::DeleteTablePath(options, TABLE_NAME);
|
|
ASSERT_TRUE(status.ok());
|
|
|
|
} |