102 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			2.7 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 SHARE
 | |
| 
 | |
| #include "gtest/gtest.h"
 | |
| #include "lib/thread/ob_async_task_queue.h"
 | |
| 
 | |
| namespace oceanbase {
 | |
| using namespace common;
 | |
| namespace share {
 | |
| 
 | |
| class ObFakeTask : public ObAsyncTask {
 | |
| public:
 | |
|   ObFakeTask(const bool copy_success, const bool process_success)
 | |
|       : copy_success_(copy_success), process_success_(process_success)
 | |
|   {}
 | |
|   virtual int process()
 | |
|   {
 | |
|     return process_success_ ? OB_SUCCESS : OB_ERROR;
 | |
|   }
 | |
|   int64_t get_deep_copy_size() const
 | |
|   {
 | |
|     return sizeof(ObFakeTask);
 | |
|   }
 | |
|   ObAsyncTask* deep_copy(char* buf, const int64_t buf_size) const;
 | |
| 
 | |
| protected:
 | |
|   bool copy_success_;
 | |
|   bool process_success_;
 | |
| };
 | |
| 
 | |
| ObAsyncTask* ObFakeTask::deep_copy(char* buf, const int64_t buf_size) const
 | |
| {
 | |
|   UNUSED(buf_size);
 | |
|   ObAsyncTask* task = NULL;
 | |
|   if (copy_success_) {
 | |
|     task = new (buf) ObFakeTask(copy_success_, process_success_);
 | |
|     memcpy(task, this, sizeof(*this));
 | |
|   }
 | |
|   return task;
 | |
| }
 | |
| 
 | |
| TEST(TestAsyncTaskQueue, init)
 | |
| {
 | |
|   ObAsyncTaskQueue queue;
 | |
|   ASSERT_EQ(OB_INVALID_ARGUMENT, queue.init(0, 0));
 | |
|   ASSERT_EQ(OB_INVALID_ARGUMENT, queue.init(1, 0));
 | |
|   ASSERT_EQ(OB_INVALID_ARGUMENT, queue.init(1, 7));
 | |
|   ASSERT_EQ(OB_SUCCESS, queue.init(1, 1024));
 | |
| 
 | |
|   ASSERT_EQ(OB_INIT_TWICE, queue.init(2, 1024));
 | |
|   queue.destroy();
 | |
| }
 | |
| 
 | |
| TEST(TestAsyncTaskQueue, push)
 | |
| {
 | |
|   ObAsyncTaskQueue queue;
 | |
|   ASSERT_EQ(OB_SUCCESS, queue.init(2, 1024));
 | |
|   ObFakeTask fail_task(false, true);
 | |
|   ASSERT_EQ(OB_ERR_UNEXPECTED, queue.push(fail_task));
 | |
|   ObFakeTask success_task(true, true);
 | |
|   ASSERT_EQ(OB_SUCCESS, queue.push(success_task));
 | |
|   queue.destroy();
 | |
| }
 | |
| 
 | |
| TEST(TestAsyncTaskQueue, run)
 | |
| {
 | |
|   ObAsyncTaskQueue queue;
 | |
|   ASSERT_EQ(OB_SUCCESS, queue.init(2, 1024));
 | |
|   ObFakeTask task(true, true);
 | |
|   for (int i = 0; i < 10; ++i) {
 | |
|     ASSERT_EQ(OB_SUCCESS, queue.push(task));
 | |
|   }
 | |
| 
 | |
|   ObFakeTask fail_task(true, false);
 | |
|   fail_task.set_retry_times(3);
 | |
|   ASSERT_EQ(OB_SUCCESS, queue.push(fail_task));
 | |
| 
 | |
|   usleep(6 * static_cast<int32_t>(fail_task.get_retry_interval()));
 | |
|   queue.destroy();
 | |
| }
 | |
| 
 | |
| }  // end namespace share
 | |
| }  // end namespace oceanbase
 | |
| 
 | |
| int main(int argc, char** argv)
 | |
| {
 | |
|   oceanbase::common::ObLogger::get_logger().set_log_level("INFO");
 | |
|   ::testing::InitGoogleTest(&argc, argv);
 | |
|   return RUN_ALL_TESTS();
 | |
| }
 | 
