89 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			2.5 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.
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef OCEANBASE_CLOG_MOCK_OB_ROOT_SERVER_H_
 | 
						|
#define OCEANBASE_CLOG_MOCK_OB_ROOT_SERVER_H_
 | 
						|
 | 
						|
#include "clog/ob_i_membership_callback.h"
 | 
						|
#include "lib/hash/ob_hashmap.h"
 | 
						|
 | 
						|
namespace oceanbase {
 | 
						|
namespace clog {
 | 
						|
class MockObRootServer : public ObIMembershipCallback {
 | 
						|
  public:
 | 
						|
  struct MockRootTableNode {
 | 
						|
    int64_t mc_timestamp_;
 | 
						|
    common::ObMemberList pre_member_list_;
 | 
						|
    common::ObMemberList cur_member_list_;
 | 
						|
 | 
						|
    MockRootTableNode() : mc_timestamp_(0)
 | 
						|
    {}
 | 
						|
    ~MockRootTableNode()
 | 
						|
    {}
 | 
						|
 | 
						|
    MockRootTableNode(const MockRootTableNode& node)
 | 
						|
    {
 | 
						|
      deep_copy(node);
 | 
						|
    }
 | 
						|
 | 
						|
    void operator=(const MockRootTableNode& node)
 | 
						|
    {
 | 
						|
      deep_copy(node);
 | 
						|
    }
 | 
						|
 | 
						|
    void reset()
 | 
						|
    {
 | 
						|
      pre_member_list_.reset();
 | 
						|
      cur_member_list_.reset();
 | 
						|
      mc_timestamp_ = 0;
 | 
						|
    }
 | 
						|
 | 
						|
    int deep_copy(const MockRootTableNode& node)
 | 
						|
    {
 | 
						|
      int ret = common::OB_SUCCESS;
 | 
						|
      if (common::OB_SUCCESS != (ret = pre_member_list_.deep_copy(node.pre_member_list_))) {
 | 
						|
        CLOG_LOG(WARN, "pre_member_list deep copy fail", "ret", ret);
 | 
						|
      } else if (common::OB_SUCCESS != (ret = cur_member_list_.deep_copy(node.cur_member_list_))) {
 | 
						|
        CLOG_LOG(WARN, "cur_member_list deep copy fail", "ret", ret);
 | 
						|
      } else {
 | 
						|
        mc_timestamp_ = node.mc_timestamp_;
 | 
						|
      }
 | 
						|
      return ret;
 | 
						|
    }
 | 
						|
  };
 | 
						|
 | 
						|
  public:
 | 
						|
  MockObRootServer();
 | 
						|
  ~MockObRootServer();
 | 
						|
  int init();
 | 
						|
  void destroy();
 | 
						|
 | 
						|
  // TODO: used to write a log
 | 
						|
  int prepare_major_freeze();
 | 
						|
 | 
						|
  int on_member_change_success(const common::ObPartitionKey& partition_key, const int64_t mc_timestamp,
 | 
						|
      const common::ObMemberList& prev_member_list, const common::ObMemberList& curr_member_list);
 | 
						|
 | 
						|
  private:
 | 
						|
  static const int64_t BUCKET_NUM = 1000;
 | 
						|
  static const int32_t MOD_ID = 789789;
 | 
						|
 | 
						|
  bool is_inited_;
 | 
						|
  common::hash::ObHashMap<common::ObPartitionKey, MockRootTableNode> maps_;
 | 
						|
  DISALLOW_COPY_AND_ASSIGN(MockObRootServer);
 | 
						|
};
 | 
						|
 | 
						|
}  // namespace clog
 | 
						|
}  // end namespace oceanbase
 | 
						|
 | 
						|
#endif  // OCEANBASE_CLOG_MOCK_OB_ROOT_SERVER_H_
 |