262 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			262 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /**
 | |
|  * Copyright (c) 2021 OceanBase
 | |
|  * OceanBase CE is licensed under Mulan PubL v2.
 | |
|  * You can use this software according to the terms and conditions of the Mulan PubL v2.
 | |
|  * You may obtain a copy of Mulan PubL v2 at:
 | |
|  *          http://license.coscl.org.cn/MulanPubL-2.0
 | |
|  * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
 | |
|  * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
 | |
|  * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
 | |
|  * See the Mulan PubL v2 for more details.
 | |
|  */
 | |
| 
 | |
| #define USING_LOG_PREFIX RPC_TEST
 | |
| 
 | |
| #include <gtest/gtest.h>
 | |
| #include "rpc/obrpc/ob_rpc_request.h"
 | |
| #include "rpc/frame/ob_net_easy.h"
 | |
| #include "rpc/frame/ob_req_deliver.h"
 | |
| #include "rpc/obrpc/ob_rpc_handler.h"
 | |
| #include "rpc/obrpc/ob_rpc_packet.h"
 | |
| #include "rpc/obrpc/ob_rpc_proxy.h"
 | |
| #include "rpc/obrpc/ob_rpc_processor.h"
 | |
| #include "rpc/obrpc/ob_rpc_net_handler.h"
 | |
| #include "rpc/ob_rpc_define.h"
 | |
| #include "common/data_buffer.h"
 | |
| #include "lib/random/ob_random.h"
 | |
| 
 | |
| using namespace oceanbase;
 | |
| using namespace oceanbase::rpc;
 | |
| using namespace oceanbase::rpc::frame;
 | |
| using namespace oceanbase::obrpc;
 | |
| using namespace oceanbase::common;
 | |
| using namespace std;
 | |
| 
 | |
| #define IO_CNT 1
 | |
| #define SEND_CNT 1
 | |
| #define ERROR_MSG "Common error"
 | |
| 
 | |
| static constexpr int64_t cluster_id = 1000;
 | |
| static bool change_src_cluster_id = false;
 | |
| 
 | |
| class TestProxy
 | |
|     : public ObRpcProxy
 | |
| {
 | |
| public:
 | |
|   DEFINE_TO(TestProxy);
 | |
| 
 | |
|   RPC_S(@PR5 test, OB_TEST_PCODE);
 | |
|   //RPC_S(@PR5 test2, OB_TEST2_PCODE, (int64_t), int64_t);
 | |
|   RPC_S(@PR5 test2, OB_TEST2_PCODE, (uint64_t));
 | |
|   RPC_S(@PR5 test_cluster_id, OB_TEST3_PCODE);
 | |
| };
 | |
| 
 | |
| class MyProcessor
 | |
|     : public TestProxy::Processor<OB_TEST_PCODE>
 | |
| {
 | |
| protected:
 | |
|   int process()
 | |
|   {
 | |
|     static int64_t rpc_count_ = 0;
 | |
|     EXPECT_FALSE(req_ == NULL);
 | |
|     EXPECT_EQ(ObRequest::OB_RPC, req_->get_type());
 | |
|     EXPECT_GT(ObTimeUtility::current_time(), get_send_timestamp());
 | |
|     EXPECT_LT(ObTimeUtility::current_time() - get_send_timestamp(), 10000);
 | |
|     if (0 == rpc_count_) {
 | |
|       EXPECT_LT(get_receive_timestamp() - get_send_timestamp(), 3000);
 | |
|     } else {
 | |
|       EXPECT_LT(get_receive_timestamp() - get_send_timestamp(), 2000);
 | |
|     }
 | |
|     EXPECT_LT(get_run_timestamp() - get_receive_timestamp(), 10000);
 | |
| 
 | |
|     //LOG_USER_ERROR(OB_ERROR);
 | |
|     //LOG_USER_WARN(OB_ERROR);
 | |
|     ++rpc_count_;
 | |
|     return OB_ERROR;
 | |
|   }
 | |
| };
 | |
| 
 | |
| class MyProcessor2
 | |
|     : public TestProxy::Processor<OB_TEST2_PCODE>
 | |
| {
 | |
| protected:
 | |
|   int process()
 | |
|   {
 | |
|     const ObRpcPacket &pkt = dynamic_cast<const ObRpcPacket&>(req_->get_packet());
 | |
|     EXPECT_EQ(arg_, pkt.get_priv_tenant_id());
 | |
|     return OB_SUCCESS;
 | |
|   }
 | |
| };
 | |
| 
 | |
| class MyProcessor3
 | |
|     : public TestProxy::Processor<OB_TEST3_PCODE>
 | |
| {
 | |
| protected:
 | |
|   int process()
 | |
|   {
 | |
|     const ObRpcPacket &pkt = dynamic_cast<const ObRpcPacket&>(req_->get_packet());
 | |
|     EXPECT_EQ(cluster_id, pkt.get_dst_cluster_id());
 | |
|     EXPECT_EQ(cluster_id, pkt.get_src_cluster_id());
 | |
|     // It is not easy to simulate the exchange of rpc between two clusters on one side
 | |
|     //Here, src_cluster_id is forcibly modified in the process to achieve a similar effect
 | |
|     if (change_src_cluster_id) {
 | |
|       const_cast<ObRpcPacket&>(pkt).set_src_cluster_id(cluster_id + 1);
 | |
|     }
 | |
|     return OB_SUCCESS;
 | |
|   }
 | |
| };
 | |
| 
 | |
| class ObTestDeliver
 | |
|     : public rpc::frame::ObReqDeliver
 | |
| {
 | |
| public:
 | |
|   int init() { return 0; }
 | |
| 
 | |
|   int deliver(rpc::ObRequest &req)
 | |
|   {
 | |
|     LOG_INFO("request", K(req));
 | |
|     /*
 | |
|       ObDataBuffer buf(new char[2048], 2048);
 | |
|       ObRpcResultCode rcode;
 | |
|       rcode.rcode_ = OB_SUCCESS;
 | |
| 
 | |
|       // LOG_INFO("server process", K(req));
 | |
|       obrpc::ObRpcPacketCode pkc =
 | |
|       reinterpret_cast<const obrpc::ObRpcPacket&>(req.get_packet()).get_pcode();
 | |
|       if (OB_TEST2_PCODE == pkc) {
 | |
|       ObRpcRequest &rpc_req = static_cast<ObRpcRequest &>(req);
 | |
|       EXPECT_TRUE(0 == rpc_req.response_success<int64_t>(&buf, 987654321, rcode, 1));
 | |
|       } else {
 | |
|       MyProcessor mp;
 | |
|       mp.init();
 | |
|       mp.set_ob_request(req);
 | |
|       mp.set_buffer(&buf);
 | |
|       mp.run();
 | |
|     */
 | |
|     const ObRpcPacket &pkt = dynamic_cast<const ObRpcPacket&>(req.get_packet());
 | |
| 
 | |
|     switch (pkt.get_pcode()) {
 | |
|       case OB_TEST_PCODE: {
 | |
|         MyProcessor mp;
 | |
|         mp.init();
 | |
|         mp.set_ob_request(req);
 | |
|         mp.run();
 | |
|       } break;
 | |
|       // case OB_TEST2_PCODE: {
 | |
|       //   MyProcessor2 mp;
 | |
|       //   mp.init();
 | |
|       //   mp.set_ob_request(req);
 | |
|       //   mp.run();
 | |
|       // } break;
 | |
|       case OB_TEST3_PCODE: {
 | |
|         MyProcessor3 mp;
 | |
|         mp.init();
 | |
|         mp.set_ob_request(req);
 | |
|         mp.run();
 | |
|       } break;
 | |
|       default:
 | |
|         break;
 | |
|     }
 | |
| 
 | |
|     EXPECT_TRUE(is_io_thread());
 | |
|     // req.get_request()->opacket = const_cast<rpc::ObPacket*>(&req.get_packet());
 | |
|     // req.set_request_rtcode(EASY_OK);
 | |
|     // easy_request_wakeup(req.get_request());
 | |
|     return 0;
 | |
|   }
 | |
| 
 | |
|   void stop() {}
 | |
| };
 | |
| 
 | |
| class TestRpcServer
 | |
|     : public ::testing::Test
 | |
| {
 | |
| public:
 | |
|   TestRpcServer()
 | |
|       : handler_(server_), transport_(NULL)
 | |
|   {}
 | |
| 
 | |
|   void SetUp() override
 | |
|   {
 | |
|     ObNetOptions opts;
 | |
|     opts.rpc_io_cnt_ = IO_CNT;
 | |
|     net_.init(opts);
 | |
|     PORT = static_cast<int32_t>(rand.get(3000, 5000));
 | |
|     while (OB_SUCCESS != net_.add_rpc_listen(PORT, handler_, transport_)) {
 | |
|       PORT = static_cast<int32_t>(rand.get(3000, 5000));
 | |
|     }
 | |
|     EXPECT_EQ(OB_SUCCESS, net_.start());
 | |
|     ObRpcNetHandler::CLUSTER_ID = cluster_id;
 | |
|   }
 | |
| 
 | |
|   void TearDown() override
 | |
|   {
 | |
|     net_.stop();
 | |
|   }
 | |
| 
 | |
| protected:
 | |
|   rpc::frame::ObNetEasy net_;
 | |
|   obrpc::ObRpcHandler handler_;
 | |
|   ObTestDeliver server_;
 | |
|   rpc::frame::ObReqTransport *transport_;
 | |
|   ObRandom rand;
 | |
|   int32_t PORT;
 | |
| };
 | |
| 
 | |
| TEST_F(TestRpcServer, TestName)
 | |
| {
 | |
|   EXPECT_FALSE(is_io_thread());
 | |
| 
 | |
|   ObAddr dst(ObAddr::IPV4, "127.0.0.1", PORT);
 | |
|   TestProxy proxy;
 | |
|   proxy.init(transport_, dst);
 | |
|   int cnt = 300;
 | |
|   while (cnt--) {
 | |
|     EXPECT_EQ(OB_ERROR, proxy.timeout(12340).test());
 | |
|   }
 | |
| 
 | |
|   ObAddr dst2(ObAddr::IPV4, "127.0.0.1", PORT+1);
 | |
|   EXPECT_EQ(OB_TIMEOUT, proxy.to(dst2).test());
 | |
| 
 | |
|   // EXPECT_EQ(OB_SUCCESS, proxy.to(dst).by(2).as(10).test2(10));
 | |
|   // EXPECT_EQ(OB_SUCCESS, proxy.to(dst).by(2).test2(OB_INVALID_TENANT_ID));
 | |
| }
 | |
| 
 | |
| TEST_F(TestRpcServer, TestClusterId)
 | |
| {
 | |
|   EXPECT_FALSE(is_io_thread());
 | |
| 
 | |
|   ObAddr dst(ObAddr::IPV4, "127.0.0.1", PORT);
 | |
|   TestProxy proxy;
 | |
|   proxy.init(transport_, dst);
 | |
|   EXPECT_EQ(OB_TIMEOUT, proxy.dst_cluster_id(cluster_id + 1).test_cluster_id());
 | |
|   EXPECT_EQ(OB_SUCCESS, proxy.dst_cluster_id(cluster_id).test_cluster_id());
 | |
|   EXPECT_EQ(OB_SUCCESS, proxy.test_cluster_id());
 | |
|   // Verify that src_cluster_id will be used as the cluster_id of the return package
 | |
|   change_src_cluster_id = true;
 | |
|   EXPECT_EQ(OB_TIMEOUT, proxy.test_cluster_id());
 | |
| }
 | |
| 
 | |
| /*
 | |
|   TEST_F(TestRpcServer, test_rpc_request)
 | |
|   {
 | |
|   ObAddr dst(ObAddr::IPV4, "127.0.0.1", PORT);
 | |
|   TestProxy proxy;
 | |
|   proxy.init(transport_, dst);
 | |
|   int64_t res = 0;
 | |
|   int64_t cnt =300;
 | |
|   while (cnt--) {
 | |
|   proxy.timeout(12340).test2(cnt, res);
 | |
|   EXPECT_TRUE(res == 987654321);
 | |
|   }
 | |
|   }
 | |
| */
 | |
| 
 | |
| 
 | |
| int main(int argc, char *argv[])
 | |
| {
 | |
|   ::testing::InitGoogleTest(&argc, argv);
 | |
|   ob_get_tsi_warning_buffer()->set_warn_log_on(true);
 | |
|   return RUN_ALL_TESTS();
 | |
| }
 | 
