milvus/internal/core/unittest/test_storage.cpp

153 lines
4.6 KiB
C++

// Copyright (C) 2019-2020 Zilliz. All rights reserved.
//
// 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
#include <gtest/gtest.h>
#include <iostream>
#include <random>
#include <string>
#include <vector>
#include "common/EasyAssert.h"
#include "storage/prometheus_client.h"
#include "storage/LocalChunkManagerSingleton.h"
#include "storage/RemoteChunkManagerSingleton.h"
#include "storage/storage_c.h"
using namespace std;
using namespace milvus;
using namespace milvus::storage;
string rootPath = "files";
string bucketName = "a-bucket";
CStorageConfig
get_azure_storage_config() {
auto endpoint = "core.windows.net";
auto accessKey = "devstoreaccount1";
auto accessValue =
"Eby8vdM02xNOcqFlqUwJPLlmEtlCDXJ1OUzFT50uSRZ6IFsuFq2UVErCz4I6tq/"
"K1SZFPTOtr/KBHBeksoGMGw==";
return CStorageConfig{endpoint,
bucketName.c_str(),
accessKey,
accessValue,
rootPath.c_str(),
"remote",
"azure",
"",
"error",
"",
false,
false,
false,
30000};
}
class StorageTest : public testing::Test {
public:
StorageTest() {
}
~StorageTest() {
}
virtual void
SetUp() {
}
};
TEST_F(StorageTest, InitLocalChunkManagerSingleton) {
auto status = InitLocalChunkManagerSingleton("tmp");
EXPECT_EQ(status.error_code, Success);
}
TEST_F(StorageTest, GetLocalUsedSize) {
int64_t size = 0;
auto lcm = LocalChunkManagerSingleton::GetInstance().GetChunkManager();
EXPECT_EQ(lcm->GetRootPath(), "/tmp/milvus/local_data/");
string test_dir = lcm->GetRootPath() + "tmp";
string test_file = test_dir + "/test.txt";
auto status = GetLocalUsedSize(test_dir.c_str(), &size);
EXPECT_EQ(status.error_code, Success);
EXPECT_EQ(size, 0);
lcm->CreateDir(test_dir);
lcm->CreateFile(test_file);
uint8_t data[5] = {0x17, 0x32, 0x45, 0x34, 0x23};
lcm->Write(test_file, data, sizeof(data));
status = GetLocalUsedSize(test_dir.c_str(), &size);
EXPECT_EQ(status.error_code, Success);
EXPECT_EQ(size, 5);
lcm->RemoveDir(test_dir);
}
TEST_F(StorageTest, InitRemoteChunkManagerSingleton) {
CStorageConfig storageConfig = get_azure_storage_config();
InitRemoteChunkManagerSingleton(storageConfig);
auto rcm =
RemoteChunkManagerSingleton::GetInstance().GetRemoteChunkManager();
EXPECT_EQ(rcm->GetRootPath(), "/tmp/milvus/remote_data");
}
TEST_F(StorageTest, InitChunkCacheSingleton) {
}
TEST_F(StorageTest, CleanRemoteChunkManagerSingleton) {
CleanRemoteChunkManagerSingleton();
}
vector<string>
split(const string& str,
const string& delim) { //将分割后的子字符串存储在vector中
vector<string> res;
if ("" == str)
return res;
string strs = str + delim;
size_t pos;
size_t size = strs.size();
for (int i = 0; i < size; ++i) {
pos = strs.find(delim, i);
if (pos < size) {
string s = strs.substr(i, pos - i);
res.push_back(s);
i = pos + delim.size() - 1;
}
}
return res;
}
TEST_F(StorageTest, GetStorageMetrics) {
auto metricsChars = GetStorageMetrics();
string helpPrefix = "# HELP ";
string familyName = "";
char* p;
const char* delim = "\n";
p = strtok(metricsChars, delim);
while (p) {
char* currentLine = p;
p = strtok(NULL, delim);
if (strncmp(currentLine, "# HELP ", 7) == 0) {
familyName = "";
continue;
} else if (strncmp(currentLine, "# TYPE ", 7) == 0) {
std::vector<string> res = split(currentLine, " ");
EXPECT_EQ(4, res.size());
familyName = res[2];
EXPECT_EQ(true, res[3] == "counter" || res[3] == "histogram");
continue;
}
EXPECT_EQ(true, familyName.length() > 0);
EXPECT_EQ(
0, strncmp(currentLine, familyName.c_str(), familyName.length()));
}
}