Add an assert and avoid std::sort(autovector) to investigate an ASAN issue

Summary:
ASAN build fails once for this error:

14:04:52 ==== Test DBTest.CompactFilesOnLevelCompaction
14:04:52 db_test: db/version_set.cc:1062: void rocksdb::VersionStorageInfo::AddFile(int, rocksdb::FileMetaData*): Assertion `level <= 0 || level_files->empty() || internal_comparator_->Compare( (*level_files)[level_files->size() - 1]->largest, f->smallest) < 0' failed.

Not abling figure out reason. We use std:vector for sorting for save and add one more assert to help figure out whether it is the sorting's problem.

Test Plan: make all check

Reviewers: yhchiang, rven, igor

Reviewed By: igor

Subscribers: leveldb, dhruba

Differential Revision: https://reviews.facebook.net/D30117
This commit is contained in:
sdong 2014-12-11 15:46:01 -08:00
parent 74b3fb6d97
commit 7ab1526c0e

View File

@ -231,13 +231,26 @@ class VersionBuilder::Rep {
base_files.size() + unordered_added_files.size()); base_files.size() + unordered_added_files.size());
// Sort added files for the level. // Sort added files for the level.
autovector<FileMetaData*> added_files; std::vector<FileMetaData*> added_files;
added_files.reserve(unordered_added_files.size());
for (const auto& pair : unordered_added_files) { for (const auto& pair : unordered_added_files) {
added_files.push_back(pair.second); added_files.push_back(pair.second);
} }
std::sort(added_files.begin(), added_files.end(), cmp); std::sort(added_files.begin(), added_files.end(), cmp);
#ifndef NDEBUG
FileMetaData* prev_file = nullptr;
#endif
for (const auto& added : added_files) { for (const auto& added : added_files) {
#ifndef NDEBUG
if (level > 0 && prev_file != nullptr) {
assert(base_vstorage_->InternalComparator()->Compare(
prev_file->smallest, added->smallest) <= 0);
}
prev_file = added;
#endif
// Add all smaller files listed in base_ // Add all smaller files listed in base_
for (auto bpos = std::upper_bound(base_iter, base_end, added, cmp); for (auto bpos = std::upper_bound(base_iter, base_end, added, cmp);
base_iter != bpos; ++base_iter) { base_iter != bpos; ++base_iter) {