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:
parent
74b3fb6d97
commit
7ab1526c0e
@ -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) {
|
||||||
|
Loading…
Reference in New Issue
Block a user