fix release order in validateNumberOfEntries

Summary:
ScopedArenaIterator should be defined after range_del_agg so that it destructs the assigned iterator, which depends on range_del_agg, before it range_del_agg is already destructed.
Closes https://github.com/facebook/rocksdb/pull/3281

Differential Revision: D6592332

Pulled By: maysamyabandeh

fbshipit-source-id: 89a15d8ed13d0fc856b0c47dce3d91778738dbac
main
Maysam Yabandeh 7 years ago committed by Facebook Github Bot
parent aa6509d8e4
commit 78c2eedb4f
  1. 4
      db/db_test_util.cc

@ -1157,11 +1157,13 @@ UpdateStatus DBTestBase::updateInPlaceNoAction(char* prevValue,
// Utility method to test InplaceUpdate // Utility method to test InplaceUpdate
void DBTestBase::validateNumberOfEntries(int numValues, int cf) { void DBTestBase::validateNumberOfEntries(int numValues, int cf) {
ScopedArenaIterator iter;
Arena arena; Arena arena;
auto options = CurrentOptions(); auto options = CurrentOptions();
InternalKeyComparator icmp(options.comparator); InternalKeyComparator icmp(options.comparator);
RangeDelAggregator range_del_agg(icmp, {} /* snapshots */); RangeDelAggregator range_del_agg(icmp, {} /* snapshots */);
// This should be defined after range_del_agg so that it destructs the
// assigned iterator before it range_del_agg is already destructed.
ScopedArenaIterator iter;
if (cf != 0) { if (cf != 0) {
iter.set( iter.set(
dbfull()->NewInternalIterator(&arena, &range_del_agg, handles_[cf])); dbfull()->NewInternalIterator(&arena, &range_del_agg, handles_[cf]));

Loading…
Cancel
Save