Skip to content

Commit

Permalink
debug
Browse files Browse the repository at this point in the history
  • Loading branch information
hx235 committed Dec 20, 2024
1 parent 20cfacf commit 2fe5224
Show file tree
Hide file tree
Showing 4 changed files with 52 additions and 8 deletions.
21 changes: 15 additions & 6 deletions db/db_wal_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1850,12 +1850,14 @@ TEST_F(DBWALTest, TrackAndVerifyWALsRecycleWAL) {
ASSERT_OK(Put("key_ignore", "wal_to_recycle"));
ASSERT_OK(Put("key_ignore1", "wal_to_recycle"));
ASSERT_OK(Put("key_ignore2", "wal_to_recycle"));
ASSERT_OK(Flush());
FlushOptions fo;
fo.wait = true;
ASSERT_OK(dbfull()->Flush(fo));

ASSERT_OK(Put("key_ignore", "wal_to_recycle"));
ASSERT_OK(Put("key_ignore1", "wal_to_recycle"));
ASSERT_OK(Put("key_ignore2", "wal_to_recycle"));
ASSERT_OK(Flush());
ASSERT_OK(dbfull()->Flush(fo));

// Stop background flush to avoid deleting any WAL
env_->SetBackgroundThreads(1, Env::HIGH);
Expand Down Expand Up @@ -1909,6 +1911,7 @@ TEST_P(DBWALTrackAndVerifyWALsWithParamsTest, Basic) {
options.avoid_flush_during_shutdown = true;
options.track_and_verify_wals = true;
options.wal_recovery_mode = GetParam();
// options.wal_compression = CompressionType::kZSTD;

DestroyAndReopen(options);

Expand Down Expand Up @@ -1940,6 +1943,12 @@ TEST_P(DBWALTrackAndVerifyWALsWithParamsTest, Basic) {
options.wal_recovery_mode ==
WALRecoveryMode::kTolerateCorruptedTailRecords) {
ASSERT_TRUE(s.IsCorruption());
// Debug
if (!(s.ToString().find(
"Mismatched last sequence number recorded in the WAL") !=
std::string::npos)) {
std::cout << s.ToString() << std::endl;
}
ASSERT_TRUE(s.ToString().find(
"Mismatched last sequence number recorded in the WAL") !=
std::string::npos);
Expand Down Expand Up @@ -2006,7 +2015,7 @@ TEST_P(DBWALTestWithParams, kTolerateCorruptedTailRecords) {

// Fill data for testing
Options options = CurrentOptions();
options.track_and_verify_wals = std::get<4>(GetParam());
options.track_and_verify_wals = false && std::get<4>(GetParam());
const size_t row_count = RecoveryTestHelper::FillData(this, &options);
// test checksum failure or parsing
RecoveryTestHelper::CorruptWAL(this, options, corrupt_offset * .3,
Expand All @@ -2030,7 +2039,7 @@ TEST_P(DBWALTestWithParams, kTolerateCorruptedTailRecords) {
TEST_P(DBWALTestWithParams, kAbsoluteConsistency) {
// Verify clean slate behavior
Options options = CurrentOptions();
options.track_and_verify_wals = std::get<4>(GetParam());
options.track_and_verify_wals = false && std::get<4>(GetParam());
const size_t row_count = RecoveryTestHelper::FillData(this, &options);
options.create_if_missing = false;
ASSERT_OK(TryReopen(options));
Expand Down Expand Up @@ -2281,7 +2290,7 @@ TEST_P(DBWALTestWithParams, kPointInTimeRecovery) {

// Fill data for testing
Options options = CurrentOptions();
options.track_and_verify_wals = std::get<4>(GetParam());
options.track_and_verify_wals = false && std::get<4>(GetParam());
options.wal_compression = compression_type;
const size_t row_count = RecoveryTestHelper::FillData(this, &options);

Expand Down Expand Up @@ -2339,7 +2348,7 @@ TEST_P(DBWALTestWithParams, kSkipAnyCorruptedRecords) {

// Fill data for testing
Options options = CurrentOptions();
options.track_and_verify_wals = std::get<4>(GetParam());
options.track_and_verify_wals = false && std::get<4>(GetParam());
options.wal_compression = compression_type;
const size_t row_count = RecoveryTestHelper::FillData(this, &options);

Expand Down
3 changes: 3 additions & 0 deletions db/log_format.h
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,9 @@ enum RecordType : uint8_t {
kUserDefinedTimestampSizeType = 10,
kRecyclableUserDefinedTimestampSizeType = 11,

// kPredecessorWALInfoType = 12,
// kRecyclePredecessorWALInfoType = 13,

// For WAL verification
kPredecessorWALInfoType = 129,
kRecyclePredecessorWALInfoType = 130,
Expand Down
18 changes: 16 additions & 2 deletions db/log_reader.cc
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
#include "db/log_reader.h"

#include <cstdio>
#include <iostream>

#include "file/sequence_file_reader.h"
#include "port/lang.h"
Expand Down Expand Up @@ -556,7 +557,7 @@ uint8_t Reader::ReadPhysicalRecord(Slice* result, size_t* drop_size,
const char* header = buffer_.data();
const uint32_t a = static_cast<uint32_t>(header[4]) & 0xff;
const uint32_t b = static_cast<uint32_t>(header[5]) & 0xff;
const uint8_t type = static_cast<uint8_t>(header[6]);
const uint8_t type = static_cast<uint8_t>(header[6]) & 0xff;
const uint32_t length = a | (b << 8);
int header_size = kHeaderSize;
const bool is_recyclable_type =
Expand All @@ -579,7 +580,14 @@ uint8_t Reader::ReadPhysicalRecord(Slice* result, size_t* drop_size,
continue;
}
}

if (track_and_verify_wals_) {
std::cout << " " << std::endl;
std::cout << "Normal: " << std::endl;
std::cout << "Type: " << std::to_string(type) << std::endl;
std::cout << "header_size: " << header_size << std::endl;
std::cout << "length: " << length << std::endl;
std::cout << "buffer_.size(): " << buffer_.size() << std::endl;
}
if (header_size + length > buffer_.size()) {
assert(buffer_.size() >= static_cast<size_t>(header_size));
*drop_size = buffer_.size();
Expand All @@ -588,6 +596,12 @@ uint8_t Reader::ReadPhysicalRecord(Slice* result, size_t* drop_size,
// `header_size + length` bytes of payload, report a corruption. The
// higher layers can decide how to handle it based on the recovery mode,
// whether this occurred at EOF, whether this is the final WAL, etc.
std::cout << " " << std::endl;
std::cout << "kBadRecordLen: " << std::endl;
std::cout << "Type: " << std::to_string(type) << std::endl;
std::cout << "header_size: " << header_size << std::endl;
std::cout << "length: " << length << std::endl;
std::cout << "buffer_.size(): " << buffer_.size() << std::endl;
return kBadRecordLen;
}

Expand Down
18 changes: 18 additions & 0 deletions db/log_writer.cc
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
#include "db/log_writer.h"

#include <cstdint>
#include <iostream>

#include "file/writable_file_writer.h"
#include "rocksdb/env.h"
Expand Down Expand Up @@ -340,6 +341,12 @@ IOStatus Writer::EmitPhysicalRecord(const WriteOptions& write_options,
crc = crc32c::Extend(crc, buf + 7, 4);
}

std::cout << " " << std::endl;
std::cout << "Emit:" << std::endl;
std::cout << "Type: " << std::to_string(static_cast<uint8_t>(t)) << std::endl;
std::cout << "Length: " << n << std::endl;
std::cout << "header_size: " << header_size << std::endl;

// Compute the crc of the record type and the payload.
uint32_t payload_crc = crc32c::Value(ptr, n);
crc = crc32c::Crc32cCombine(crc, payload_crc, n);
Expand Down Expand Up @@ -395,6 +402,17 @@ IOStatus Writer::MaybeSwitchToNewBlock(const WriteOptions& write_options,
}

block_offset_ = 0;
std::cout << " " << std::endl;
std::cout << "Switching to a new block" << std::endl;
} else {
std::cout << " " << std::endl;
std::cout << "Did not switch to a new block" << std::endl;
std::cout << "leftover: " << leftover << std::endl;
std::cout << "header_size_: " << header_size_ << std::endl;
std::cout << "content_to_write.size(): " << content_to_write.size()
<< std::endl;
std::cout << "(int)content_to_write.size(): "
<< (int)content_to_write.size() << std::endl;
}
return s;
}
Expand Down

0 comments on commit 2fe5224

Please sign in to comment.