/** * 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. */ #ifndef _MOCK_ELECTION_RPC_H_ #define _MOCK_ELECTION_RPC_H_ #include "loss.h" #include "outage.h" #include "election/ob_election.h" #include "election/ob_election_rpc_stub.h" namespace oceanbase { namespace election { class ObElectionServer; } namespace tests { namespace election { using namespace oceanbase::common; using namespace oceanbase::election; class MockObElectionRpcStub : public ObElectionRpcStub { public: virtual int init( const ObClientManager* client_mgr, ThreadSpecificBuffer* buffer, ObElection* e, const int64_t timeout); virtual void destroy(void); public: virtual int init(ObElectionServer& server); static const int64_t timeout = 3000000; public: virtual int send_devote_prepare(void); virtual int send_devote_vote(const ObServer& server); virtual int send_devote_success(const ObServer& server); virtual int send_vote_prepare(void); virtual int send_vote_vote(const ObServer& cur_leader, const ObServer& new_leader); virtual int send_vote_success(const ObServer& cur_leader, const ObServer& new_leader); public: void set_outage_for(ObElectionVoteMsgType type, int64_t start, int64_t end); void set_outage_all(int64_t start, int64_t end); void reset_outage_for(ObElectionVoteMsgType type); void reset_outage_all(void); void set_loss_all(int64_t loss_rate, int64_t start = INT64_MIN, int64_t end = INT64_MAX); void reset_loss_all(void); private: Outage outage_map_[MAX_VOTE_MSG_TYPE]; Loss loss_map_[MAX_VOTE_MSG_TYPE]; }; } // namespace election } // namespace tests } // namespace oceanbase #endif