1. solved the previous delayed unit test file size is too large (1.7G+) and the unit test link time is too long problem problems 2. Unify all unit tests into one file to significantly reduce unit test execution time to less than 3 mins 3. temporarily disable stream_load_test.cpp, metrics_action_test.cpp, load_channel_mgr_test.cpp because it will re-implement part of the code and affect other tests
82 lines
3.1 KiB
C++
82 lines
3.1 KiB
C++
// Licensed to the Apache Software Foundation (ASF) under one
|
|
// or more contributor license agreements. See the NOTICE file
|
|
// distributed with this work for additional information
|
|
// regarding copyright ownership. The ASF licenses this file
|
|
// to you 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 "agent/heartbeat_server.h"
|
|
|
|
#include <ctime>
|
|
|
|
#include "gen_cpp/HeartbeatService_types.h"
|
|
#include "gen_cpp/Types_types.h"
|
|
#include "gmock/gmock.h"
|
|
#include "gtest/gtest.h"
|
|
#include "util/logging.h"
|
|
|
|
using ::testing::_;
|
|
using ::testing::Return;
|
|
using ::testing::SetArgPointee;
|
|
using std::string;
|
|
using std::vector;
|
|
|
|
namespace doris {
|
|
|
|
TEST(HeartbeatTest, TestHeartbeat) {
|
|
setenv("DORIS_HOME", "./", 1);
|
|
THeartbeatResult heartbeat_result;
|
|
TMasterInfo ori_master_info;
|
|
ori_master_info.cluster_id = -1;
|
|
ori_master_info.epoch = 0;
|
|
ori_master_info.network_address.hostname = "";
|
|
ori_master_info.network_address.port = 0;
|
|
HeartbeatServer heartbeat_server(&ori_master_info);
|
|
|
|
heartbeat_server.heartbeat(heartbeat_result, master_info);
|
|
EXPECT_EQ(TStatusCode::OK, heartbeat_result.status.status_code);
|
|
EXPECT_EQ(master_info.epoch, heartbeat_server._epoch);
|
|
EXPECT_EQ(master_info.cluster_id, heartbeat_server._master_info->cluster_id);
|
|
EXPECT_EQ(master_info.network_address.hostname,
|
|
heartbeat_server._master_info->network_address.hostname);
|
|
EXPECT_EQ(master_info.network_address.port,
|
|
heartbeat_server._master_info->network_address.port);
|
|
|
|
// Diff cluster heartbeat
|
|
master_info.cluster_id = 2;
|
|
heartbeat_server.heartbeat(heartbeat_result, master_info);
|
|
EXPECT_EQ(TStatusCode::RUNTIME_ERROR, heartbeat_result.status.status_code);
|
|
|
|
// New master but epoch small
|
|
master_info.cluster_id = 1;
|
|
master_info.epoch = 9;
|
|
master_info.network_address.hostname = "new_host";
|
|
master_info.network_address.port = 54321;
|
|
heartbeat_server.heartbeat(heartbeat_result, master_info);
|
|
EXPECT_EQ(TStatusCode::RUNTIME_ERROR, heartbeat_result.status.status_code);
|
|
|
|
// New master and epoch bigger
|
|
master_info.epoch = 11;
|
|
heartbeat_server.heartbeat(heartbeat_result, master_info);
|
|
EXPECT_EQ(TStatusCode::OK, heartbeat_result.status.status_code);
|
|
EXPECT_EQ(master_info.epoch, heartbeat_server._epoch);
|
|
EXPECT_EQ(master_info.network_address.hostname,
|
|
heartbeat_server._master_info->network_address.hostname);
|
|
EXPECT_EQ(master_info.network_address.port,
|
|
heartbeat_server._master_info->network_address.port);
|
|
|
|
heartbeat_server._olap_rootpath_instance = ori_olap_rootpath;
|
|
}
|
|
|
|
} // namespace doris
|