@ -8237,16 +8237,18 @@ TEST_F(DBTest, CloseSpeedup) {
Destroy ( options ) ;
Destroy ( options ) ;
}
}
class DelayedMergeOperator : public Associative MergeOperator {
class DelayedMergeOperator : public MergeOperator {
private :
private :
DBTest * db_test_ ;
DBTest * db_test_ ;
public :
public :
explicit DelayedMergeOperator ( DBTest * d ) : db_test_ ( d ) { }
explicit DelayedMergeOperator ( DBTest * d ) : db_test_ ( d ) { }
virtual bool Merge ( const Slice & key , const Slice * existing_value ,
virtual bool FullMerge ( const Slice & key , const Slice * existing_value ,
const Slice & value , std : : string * new_value ,
const std : : deque < std : : string > & operand_list ,
std : : string * new_value ,
Logger * logger ) const override {
Logger * logger ) const override {
db_test_ - > env_ - > addon_time_ . fetch_add ( 1000 ) ;
db_test_ - > env_ - > addon_time_ . fetch_add ( 1000 ) ;
* new_value = " " ;
return true ;
return true ;
}
}
@ -8262,6 +8264,8 @@ TEST_F(DBTest, MergeTestTime) {
// Enable time profiling
// Enable time profiling
SetPerfLevel ( kEnableTime ) ;
SetPerfLevel ( kEnableTime ) ;
this - > env_ - > addon_time_ . store ( 0 ) ;
this - > env_ - > addon_time_ . store ( 0 ) ;
this - > env_ - > time_elapse_only_sleep_ = true ;
this - > env_ - > no_sleep_ = true ;
Options options ;
Options options ;
options = CurrentOptions ( options ) ;
options = CurrentOptions ( options ) ;
options . statistics = rocksdb : : CreateDBStatistics ( ) ;
options . statistics = rocksdb : : CreateDBStatistics ( ) ;
@ -8282,11 +8286,7 @@ TEST_F(DBTest, MergeTestTime) {
std : : string result ;
std : : string result ;
db_ - > Get ( opt , " foo " , & result ) ;
db_ - > Get ( opt , " foo " , & result ) ;
ASSERT_GT ( TestGetTickerCount ( options , MERGE_OPERATION_TOTAL_TIME ) , 1200000 ) ;
ASSERT_EQ ( 1000000 , TestGetTickerCount ( options , MERGE_OPERATION_TOTAL_TIME ) ) ;
// Counter upper bound depends on platform. Just check a conservative
// large value.
ASSERT_LT ( TestGetTickerCount ( options , MERGE_OPERATION_TOTAL_TIME ) ,
1000000000 ) ;
ReadOptions read_options ;
ReadOptions read_options ;
std : : unique_ptr < Iterator > iter ( db_ - > NewIterator ( read_options ) ) ;
std : : unique_ptr < Iterator > iter ( db_ - > NewIterator ( read_options ) ) ;
@ -8297,15 +8297,11 @@ TEST_F(DBTest, MergeTestTime) {
}
}
ASSERT_EQ ( 1 , count ) ;
ASSERT_EQ ( 1 , count ) ;
ASSERT_EQ ( 2000000 , TestGetTickerCount ( options , MERGE_OPERATION_TOTAL_TIME ) ) ;
ASSERT_GT ( TestGetTickerCount ( options , MERGE_OPERATION_TOTAL_TIME ) , 3200000 ) ;
// Counter upper bound depends on platform. Just check a conservative
// large value.
ASSERT_LT ( TestGetTickerCount ( options , MERGE_OPERATION_TOTAL_TIME ) ,
1000000000 ) ;
# if ROCKSDB_USING_THREAD_STATUS
# if ROCKSDB_USING_THREAD_STATUS
ASSERT_GT ( TestGetTickerCount ( options , FLUSH_WRITE_BYTES ) , 0 ) ;
ASSERT_GT ( TestGetTickerCount ( options , FLUSH_WRITE_BYTES ) , 0 ) ;
# endif // ROCKSDB_USING_THREAD_STATUS
# endif // ROCKSDB_USING_THREAD_STATUS
this - > env_ - > time_elapse_only_sleep_ = false ;
}
}
# ifndef ROCKSDB_LITE
# ifndef ROCKSDB_LITE