266 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			266 lines
		
	
	
		
			12 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_STORAGE_MOCK_OB_PARTITION_STORAGE_H_
 | |
| #define OCEANBASE_STORAGE_MOCK_OB_PARTITION_STORAGE_H_
 | |
| #include "storage/ob_i_partition_storage.h"
 | |
| #include "storage/ob_partition_merge_task.h"
 | |
| #include "storage/ob_replay_status.h"
 | |
| #include "storage/ob_saved_storage_info.h"
 | |
| #include "gmock/gmock.h"
 | |
| 
 | |
| namespace oceanbase {
 | |
| namespace storage {
 | |
| class MockObIPartitionStorage : public ObIPartitionStorage {
 | |
| public:
 | |
|   virtual ~MockObIPartitionStorage()
 | |
|   {}
 | |
|   MOCK_METHOD5(init,
 | |
|       int(const common::ObPartitionKey &pkey,
 | |
|           ObIPartitionComponentFactory *cp_fty,
 | |
|           share::schema::ObMultiVersionSchemaService *schema_service,
 | |
|           transaction::ObTransService *txs);
 | |
|   MOCK_METHOD0(destroy, void());
 | |
| 
 | |
| 
 | |
| 
 | |
|   MOCK_METHOD2(table_scan,
 | |
|         int(ObTableScanParam ¶m,
 | |
|             common::ObNewRowIterator *&result));
 | |
| 
 | |
|   MOCK_METHOD4(join_mv_scan,
 | |
|       int(ObTableScanParam &left_param,
 | |
|           ObTableScanParam &right_param,
 | |
|           ObIPartitionStorage &right_storage,
 | |
|           common::ObNewRowIterator *&result));
 | |
| 
 | |
|   MOCK_METHOD1(revert_scan_iter, int(common::ObNewRowIterator *iter));
 | |
| 
 | |
|   MOCK_METHOD5(delete_rows,
 | |
|       int(const ObStoreCtx &ctx,
 | |
|           const ObDMLBaseParam &dml_param,
 | |
|           const common::ObIArray<uint64_t> &column_ids,
 | |
|           common::ObNewRowIterator *row_iter,
 | |
|           int64_t &affected_rows));
 | |
|   MOCK_METHOD4(delete_row,
 | |
|                int(const ObStoreCtx &ctx,
 | |
|                    const ObDMLBaseParam &dml_param,
 | |
|                    const common::ObIArray<uint64_t> &column_ids,
 | |
|                    const common::ObNewRow &row));
 | |
|   MOCK_METHOD5(insert_rows,
 | |
|       int(const ObStoreCtx &ctx,
 | |
|           const ObDMLBaseParam &dml_param,
 | |
|           const common::ObIArray<uint64_t> &column_ids,
 | |
|           common::ObNewRowIterator *row_iter,
 | |
|           int64_t &affected_rows));
 | |
|   MOCK_METHOD8(insert_row,
 | |
|       int(const ObStoreCtx &ctx,
 | |
|           const ObDMLBaseParam &dml_param,
 | |
|           const common::ObIArray<uint64_t> &column_ids,
 | |
|           const common::ObIArray<uint64_t> &duplicated_column_ids,
 | |
|           const common::ObNewRow &row,
 | |
|           const ObInsertFlag flag,
 | |
|           int64_t &affected_rows,
 | |
|           common::ObNewRowIterator *&duplicated_rows));
 | |
|   MOCK_METHOD1(revert_insert_iter,
 | |
|       int(common::ObNewRowIterator *iter));
 | |
| 
 | |
|   MOCK_METHOD6(update_rows,
 | |
|       int(const ObStoreCtx &ctx,
 | |
|           const ObDMLBaseParam &dml_param,
 | |
|           const common::ObIArray<uint64_t> &column_ids,
 | |
|           const common::ObIArray< uint64_t> &updated_column_ids,
 | |
|           common::ObNewRowIterator *row_iter,
 | |
|           int64_t &affected_rows));
 | |
|   MOCK_METHOD6(update_row,
 | |
|       int(const ObStoreCtx &ctx,
 | |
|           const ObDMLBaseParam &dml_param,
 | |
|           const common::ObIArray<uint64_t> &column_ids,
 | |
|           const common::ObIArray<uint64_t> &updated_column_ids,
 | |
|           const common::ObNewRow &old_row,
 | |
|           const common::ObNewRow &new_row));
 | |
|   MOCK_METHOD6(lock_rows,
 | |
|       int(const ObStoreCtx &ctx,
 | |
|           const ObDMLBaseParam &dml_param,
 | |
|           const int64_t abs_lock_timeout,
 | |
|           common::ObNewRowIterator *row_iter,
 | |
|           ObLockFlag lock_flag,
 | |
|           int64_t &affected_rows));
 | |
|   MOCK_METHOD5(lock_rows,
 | |
|       int(const ObStoreCtx &ctx,
 | |
|           const ObDMLBaseParam &dml_param,
 | |
|           const int64_t abs_lock_timeout,
 | |
|           const common::ObNewRow &row,
 | |
|           ObLockFlag lock_flag));
 | |
|   MOCK_METHOD2(freeze_memtable, int(const FreezeType freeze_type, uint64_t frozen_version));
 | |
|   MOCK_METHOD1(migrate, int(uint64_t migrate_version ));
 | |
|   MOCK_METHOD3(merge, int(uint64_t frozen_version, int64_t &merge_version, ObIPartitionReport &report));
 | |
|   MOCK_METHOD3(get_concurrent_cnt, int(uint64_t table_id, int64_t schema_version, int64_t &concurrent_cnt));
 | |
| 
 | |
|   MOCK_CONST_METHOD1(can_be_minor_merged, bool(const common::ObVersion &version));
 | |
|   MOCK_CONST_METHOD1(get_minor_merge_version, int(common::ObVersion &merge_version));
 | |
|   MOCK_METHOD2(minor_merge, int(const common::ObVersion &start_version,
 | |
|                                 bool &merge));
 | |
|   MOCK_CONST_METHOD1(get_merged_version, int(common::ObVersion &merged_version));
 | |
|   MOCK_METHOD0(dump, int());
 | |
|   MOCK_METHOD4(get_build_index_param, int(
 | |
|       const uint64_t index_id,
 | |
|       const int64_t schema_version,
 | |
|       compaction::ObBuildIndexParam ¶m));
 | |
|   MOCK_METHOD2(get_build_index_context, int(
 | |
|       const compaction::ObBuildIndexParam ¶m,
 | |
|       compaction::ObBuildIndexContext &context));
 | |
|   MOCK_METHOD3(local_sort_index_by_range, int(
 | |
|       const int64_t idx,
 | |
|       const compaction::ObBuildIndexParam ¶m,
 | |
|       const compaction::ObBuildIndexContext &context));
 | |
|   MOCK_METHOD4(add_build_index_sstable, int(
 | |
|       const share::schema::ObTableSchema &index_schema,
 | |
|       const ObVersion version,
 | |
|       const int64_t schema_cnt,
 | |
|       ObExternalSort<ObStoreRow, ObStoreRowComparer> &external_sort));
 | |
|   MOCK_CONST_METHOD0(get_merge_schema_version, int64_t());
 | |
|   MOCK_CONST_METHOD0(get_merge_data_version, int64_t());
 | |
|   MOCK_METHOD2(check_unique_index_valid, int(
 | |
|         const int64_t check_snapshot_version,
 | |
|         const share::schema::ObTableSchema &index_schema));
 | |
|   MOCK_METHOD2(normal_minor_merge, int (
 | |
|         const ObVersion &start_version,
 | |
|         bool &is_major_freeze_store));
 | |
|   MOCK_METHOD3(build_index_minor_merge, int(
 | |
|       const ObVersion &start_version,
 | |
|       const ObIArray<uint64_t> &to_minor_merge_tables,
 | |
|       bool &is_major_freeze_store));
 | |
|   MOCK_METHOD4(merge_local_sort_index, int(
 | |
|       const compaction::ObBuildIndexParam ¶m,
 | |
|       const ObIArray<ObExternalSort<ObStoreRow, ObStoreRowComparer> *> &local_sorters,
 | |
|       ObExternalSort<ObStoreRow, ObStoreRowComparer> &merge_sorter,
 | |
|       compaction::ObBuildIndexContext *context));
 | |
|   MOCK_METHOD2(check_index_need_build, int(const share::schema::ObTableSchema &index_schema, bool &need_build));
 | |
|   MOCK_METHOD2(set_build_index_ret, int(const int64_t index_id, const int ret_code));
 | |
| 
 | |
|   MOCK_METHOD0(retire_sorted_store, int());
 | |
|   MOCK_METHOD1(halt_prewarm, int(bool only_clear_memstore));
 | |
|   MOCK_METHOD1(purge_retire_stores, int(uint64_t &last_replay_log_id));
 | |
| 
 | |
|   MOCK_METHOD1(set_merge_status, void(bool merge_success));
 | |
|   MOCK_METHOD0(can_schedule_merge, bool());
 | |
|   MOCK_METHOD2(remove_store, int(const common::ObVersion &version, const bool write_redo_log));
 | |
|   MOCK_METHOD3(add_ssstores,
 | |
|                int(const ObIArray<ObSSStore *> &ssstores,
 | |
|                    const bool clear_all_stores,
 | |
|                    const bool to_empty_stores));
 | |
| 
 | |
|   MOCK_METHOD0(adjust_freeze_status, int());
 | |
|   MOCK_METHOD1(get_status, enum ObPartitionStorageStatus(const uint64_t frozen_version));
 | |
|   MOCK_METHOD1(get_all_tables, int (ObTablesHandle &handle));
 | |
|   MOCK_METHOD1(save_base_storage_info, int(const common::ObBaseStorageInfo &info));
 | |
|   MOCK_METHOD1(get_base_storage_info, int(common::ObBaseStorageInfo &info));
 | |
|   MOCK_METHOD3(get_saved_storage_info,
 | |
|       int(const ObStoreType &type, ObSavedStorageInfo &info, common::ObVersion &version));
 | |
|   MOCK_METHOD1(get_store_infos, int(ObIArray<ObStoreInfo> &store_infos));
 | |
|   MOCK_METHOD1(save_frozen_base_storage_info, int(const ObSavedStorageInfo &info));
 | |
| 
 | |
| 
 | |
|   // leader or follower
 | |
|   MOCK_METHOD1(lock, int(const ObStoreCtx &ctx));
 | |
| 
 | |
|   MOCK_METHOD2(get_scan_cost, int(const ObTableScanParam ¶m,
 | |
|                                         ObPartitionEst &cost_estimate));
 | |
| 
 | |
|   MOCK_METHOD5(get_batch_rows, int(const ObTableScanParam ¶m,
 | |
|                                    const storage::ObBatch &batch,
 | |
|                                    int64_t &rows,
 | |
|                                    int64_t &rows_unreliable,
 | |
|                                    common::ObIArray<common::ObEstRowCountRecord> &est_records));
 | |
| 
 | |
| 
 | |
|   MOCK_METHOD2(get_table_stat, int(const uint64_t table_id, common::ObTableStat &stat));
 | |
| 
 | |
|   // write ssstore objects @version tree to data file , used by write_check_point
 | |
|   MOCK_METHOD3(serialize,
 | |
|       int (ObArenaAllocator &allocator, char *&new_buf, int64_t &serialize_size));
 | |
| 
 | |
|   // read ssstore objects from data file to construct partition storage's version tree.
 | |
|   MOCK_METHOD3(deserialize,
 | |
|       int (const char *buf, const int64_t buf_len, int64_t &pos));
 | |
| 
 | |
|   MOCK_METHOD0(get_serialize_size, int64_t());
 | |
| 
 | |
| 
 | |
|   MOCK_METHOD0( get_storage_log_seq_num, int64_t());
 | |
|   MOCK_CONST_METHOD0 (get_partition_key, const common::ObPartitionKey &());
 | |
|   MOCK_CONST_METHOD0 (get_replication_group_key, const ObRGKey &());
 | |
|   MOCK_METHOD0 (has_memstore, bool());
 | |
|   MOCK_METHOD0 (get_memstore_allocator, common::ObIAllocator &());
 | |
|   MOCK_CONST_METHOD0 (get_schema_service, const share::schema::ObMultiVersionSchemaService *());
 | |
| 
 | |
|   MOCK_METHOD5(replay_base_storage_log, int(const int64_t log_seq_num,
 | |
|       const int64_t subcmd,
 | |
|       const char *buf,
 | |
|       const int64_t len,
 | |
|       int64_t &pos));
 | |
| 
 | |
|   MOCK_METHOD1(pre_alloc_memstore, int(const bool is_minor_freeze));
 | |
|   MOCK_METHOD1(new_active_memstore, int(const ObSavedStorageInfo &info));
 | |
|   MOCK_METHOD1(effect_new_active_memstore, int(common::ObVersion &version));
 | |
|   MOCK_METHOD0(clean_new_active_memstore, int());
 | |
|   MOCK_METHOD1(get_partition_ss_store_info, int(common::ObArray<PartitionSSStoreInfo> &partition_ss_store_info_list));
 | |
|   MOCK_METHOD1(get_sstore_min_version, int(common::ObVersion &min_version));
 | |
|   MOCK_METHOD1(do_warm_up_request, int(const oceanbase::storage::ObIWarmUpRequest*));
 | |
|   MOCK_METHOD2(check_store_can_replay,
 | |
|                int (ObSSStore &store, bool &replay));
 | |
|   MOCK_METHOD2(set_replica_type, int(const common::ObReplicaType &replica_type,
 | |
|         const bool write_redo_log));
 | |
|   MOCK_METHOD0(get_replica_type, common::ObReplicaType());
 | |
|   MOCK_METHOD5(split_macros, int(common::ObIAllocator &allocator,
 | |
|                                  const common::ObIArray<common::ObStoreRange> &ranges,
 | |
|                                  const int64_t parallelism,
 | |
|                                  ObIArray<common::ObStoreRange> &splitted_ranges,
 | |
|                                  common::ObIArray<int64_t> &split_index));
 | |
|   MOCK_METHOD2(append_local_sort_data,
 | |
|       int(
 | |
|         const share::ObBuildIndexAppendLocalDataParam ¶m,
 | |
|         common::ObNewRowIterator &iter));
 | |
|   MOCK_METHOD3(append_sstable,
 | |
|       int(
 | |
|         const share::ObBuildIndexAppendSSTableParam ¶m,
 | |
|         common::ObNewRowIterator &iter,
 | |
|         ObSSStore *&store));
 | |
|   MOCK_METHOD7(query_range_to_macros, int(common::ObIAllocator &allocator,
 | |
|   																		const common::ObIArray<common::ObStoreRange> &ranges,
 | |
| 																			const int64_t type,
 | |
| 																			uint64_t *macros_count,
 | |
| 																			const int64_t *parallelism,
 | |
| 																			ObIArray<common::ObStoreRange> *splitted_ranges,
 | |
| 																			common::ObIArray<int64_t> *split_index));
 | |
|   MOCK_METHOD2(get_migrating_store, int(const common::ObVersion &migrate_version,
 | |
|                                     ObTablesHandle &handle));
 | |
|   virtual int put_rows(const ObStoreCtx &ctx,
 | |
|                        const ObDMLBaseParam &dml_param,
 | |
|                        const common::ObIArray<uint64_t> &column_ids,
 | |
|                        common::ObNewRowIterator *row_iter,
 | |
|                        int64_t &affected_rows) override
 | |
|   {
 | |
|     UNUSED(ctx);
 | |
|     UNUSED(dml_param);
 | |
|     UNUSED(column_ids);
 | |
|     UNUSED(row_iter);
 | |
|     UNUSED(affected_rows);
 | |
|     return OB_NOT_SUPPORTED;
 | |
|   }
 | |
| };
 | |
| 
 | |
| }  // namespace storage
 | |
| }  // namespace oceanbase
 | |
| #endif  // OCEANBASE_STORAGE_MOCK_OB_PARTITION_H_
 | 
