@nxtedition/rocksdb 6.0.2 → 7.0.0-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/BUILDING.md +12 -4
- package/binding.cc +589 -128
- package/chained-batch.js +6 -6
- package/deps/rocksdb/rocksdb/CMakeLists.txt +9 -0
- package/deps/rocksdb/rocksdb/Makefile +16 -5
- package/deps/rocksdb/rocksdb/TARGETS +23 -2
- package/deps/rocksdb/rocksdb/cmake/modules/CxxFlags.cmake +7 -0
- package/deps/rocksdb/rocksdb/cmake/modules/FindJeMalloc.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/FindNUMA.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/FindSnappy.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/FindTBB.cmake +33 -0
- package/deps/rocksdb/rocksdb/cmake/modules/Findgflags.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/Findlz4.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/Finduring.cmake +26 -0
- package/deps/rocksdb/rocksdb/cmake/modules/Findzstd.cmake +29 -0
- package/deps/rocksdb/rocksdb/cmake/modules/ReadVersion.cmake +10 -0
- package/deps/rocksdb/rocksdb/db/builder.cc +12 -4
- package/deps/rocksdb/rocksdb/db/c.cc +26 -0
- package/deps/rocksdb/rocksdb/db/c_test.c +3 -0
- package/deps/rocksdb/rocksdb/db/column_family.cc +8 -2
- package/deps/rocksdb/rocksdb/db/compaction/compaction_job.cc +29 -6
- package/deps/rocksdb/rocksdb/db/compaction/compaction_job.h +8 -2
- package/deps/rocksdb/rocksdb/db/compaction/compaction_job_test.cc +16 -4
- package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_test.cc +2 -1
- package/deps/rocksdb/rocksdb/db/compaction/compaction_service_test.cc +16 -0
- package/deps/rocksdb/rocksdb/db/db_basic_test.cc +402 -30
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl.cc +2 -12
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl.h +14 -0
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_compaction_flush.cc +7 -5
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_experimental.cc +1 -1
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_open.cc +33 -7
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_readonly.cc +54 -23
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_readonly.h +3 -0
- package/deps/rocksdb/rocksdb/db/db_impl/db_impl_secondary.cc +8 -1
- package/deps/rocksdb/rocksdb/db/db_options_test.cc +16 -0
- package/deps/rocksdb/rocksdb/db/db_rate_limiter_test.cc +14 -15
- package/deps/rocksdb/rocksdb/db/db_readonly_with_timestamp_test.cc +331 -0
- package/deps/rocksdb/rocksdb/db/db_secondary_test.cc +5 -0
- package/deps/rocksdb/rocksdb/db/db_test.cc +16 -0
- package/deps/rocksdb/rocksdb/db/db_test2.cc +221 -92
- package/deps/rocksdb/rocksdb/db/db_test_util.cc +6 -2
- package/deps/rocksdb/rocksdb/db/db_test_util.h +4 -2
- package/deps/rocksdb/rocksdb/db/db_with_timestamp_basic_test.cc +1 -171
- package/deps/rocksdb/rocksdb/db/db_with_timestamp_test_util.cc +96 -0
- package/deps/rocksdb/rocksdb/db/db_with_timestamp_test_util.h +126 -0
- package/deps/rocksdb/rocksdb/db/experimental.cc +1 -1
- package/deps/rocksdb/rocksdb/db/external_sst_file_basic_test.cc +57 -0
- package/deps/rocksdb/rocksdb/db/external_sst_file_ingestion_job.cc +13 -2
- package/deps/rocksdb/rocksdb/db/external_sst_file_ingestion_job.h +2 -0
- package/deps/rocksdb/rocksdb/db/flush_job.cc +10 -11
- package/deps/rocksdb/rocksdb/db/import_column_family_job.cc +11 -1
- package/deps/rocksdb/rocksdb/db/import_column_family_test.cc +6 -0
- package/deps/rocksdb/rocksdb/db/repair.cc +12 -1
- package/deps/rocksdb/rocksdb/db/repair_test.cc +32 -10
- package/deps/rocksdb/rocksdb/db/snapshot_impl.h +3 -1
- package/deps/rocksdb/rocksdb/db/table_cache.cc +19 -127
- package/deps/rocksdb/rocksdb/db/table_cache.h +3 -2
- package/deps/rocksdb/rocksdb/db/table_cache_sync_and_async.h +140 -0
- package/deps/rocksdb/rocksdb/db/version_builder_test.cc +130 -128
- package/deps/rocksdb/rocksdb/db/version_edit.cc +20 -0
- package/deps/rocksdb/rocksdb/db/version_edit.h +13 -4
- package/deps/rocksdb/rocksdb/db/version_edit_test.cc +14 -14
- package/deps/rocksdb/rocksdb/db/version_set.cc +205 -212
- package/deps/rocksdb/rocksdb/db/version_set.h +11 -0
- package/deps/rocksdb/rocksdb/db/version_set_sync_and_async.h +154 -0
- package/deps/rocksdb/rocksdb/db/version_set_test.cc +10 -9
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_common.h +2 -0
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_gflags.cc +13 -0
- package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_test_base.cc +15 -0
- package/deps/rocksdb/rocksdb/file/file_prefetch_buffer.cc +159 -65
- package/deps/rocksdb/rocksdb/file/file_prefetch_buffer.h +43 -21
- package/deps/rocksdb/rocksdb/file/prefetch_test.cc +142 -17
- package/deps/rocksdb/rocksdb/file/writable_file_writer.cc +23 -27
- package/deps/rocksdb/rocksdb/file/writable_file_writer.h +2 -3
- package/deps/rocksdb/rocksdb/include/rocksdb/advanced_options.h +23 -5
- package/deps/rocksdb/rocksdb/include/rocksdb/c.h +14 -1
- package/deps/rocksdb/rocksdb/include/rocksdb/file_system.h +2 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/options.h +17 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/perf_context.h +2 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/snapshot.h +4 -1
- package/deps/rocksdb/rocksdb/include/rocksdb/statistics.h +3 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/utilities/options_type.h +189 -0
- package/deps/rocksdb/rocksdb/include/rocksdb/version.h +1 -1
- package/deps/rocksdb/rocksdb/monitoring/perf_context.cc +5 -0
- package/deps/rocksdb/rocksdb/monitoring/statistics.cc +1 -1
- package/deps/rocksdb/rocksdb/options/cf_options.cc +13 -0
- package/deps/rocksdb/rocksdb/options/db_options.cc +8 -0
- package/deps/rocksdb/rocksdb/options/db_options.h +1 -0
- package/deps/rocksdb/rocksdb/options/options.cc +7 -0
- package/deps/rocksdb/rocksdb/options/options_helper.cc +4 -0
- package/deps/rocksdb/rocksdb/options/options_settable_test.cc +6 -4
- package/deps/rocksdb/rocksdb/options/options_test.cc +107 -9
- package/deps/rocksdb/rocksdb/src.mk +4 -1
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_builder.cc +9 -4
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_iterator.cc +80 -6
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_iterator.h +8 -2
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader.cc +81 -757
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader.h +21 -15
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader_impl.h +9 -3
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader_sync_and_async.h +754 -0
- package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader_test.cc +2 -1
- package/deps/rocksdb/rocksdb/table/block_based/block_prefetcher.cc +8 -0
- package/deps/rocksdb/rocksdb/table/block_based/filter_block.h +1 -10
- package/deps/rocksdb/rocksdb/table/block_based/filter_block_reader_common.cc +59 -1
- package/deps/rocksdb/rocksdb/table/block_based/filter_block_reader_common.h +18 -0
- package/deps/rocksdb/rocksdb/table/block_based/full_filter_block.cc +0 -61
- package/deps/rocksdb/rocksdb/table/block_based/full_filter_block.h +0 -13
- package/deps/rocksdb/rocksdb/table/block_based/index_reader_common.cc +1 -1
- package/deps/rocksdb/rocksdb/table/block_based/partitioned_filter_block.cc +3 -2
- package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_iterator.cc +2 -2
- package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_reader.cc +2 -1
- package/deps/rocksdb/rocksdb/table/block_based/uncompression_dict_reader.cc +2 -1
- package/deps/rocksdb/rocksdb/table/block_fetcher.cc +60 -2
- package/deps/rocksdb/rocksdb/table/block_fetcher.h +2 -0
- package/deps/rocksdb/rocksdb/table/merging_iterator.cc +39 -0
- package/deps/rocksdb/rocksdb/table/multiget_context.h +46 -2
- package/deps/rocksdb/rocksdb/table/sst_file_dumper.cc +2 -1
- package/deps/rocksdb/rocksdb/table/sst_file_dumper.h +1 -1
- package/deps/rocksdb/rocksdb/table/table_reader.h +13 -0
- package/deps/rocksdb/rocksdb/table/unique_id.cc +27 -0
- package/deps/rocksdb/rocksdb/table/unique_id_impl.h +3 -0
- package/deps/rocksdb/rocksdb/test_util/testutil.cc +2 -0
- package/deps/rocksdb/rocksdb/tools/db_bench_tool.cc +23 -7
- package/deps/rocksdb/rocksdb/tools/sst_dump_tool.cc +9 -1
- package/deps/rocksdb/rocksdb/util/async_file_reader.cc +72 -0
- package/deps/rocksdb/rocksdb/util/async_file_reader.h +144 -0
- package/deps/rocksdb/rocksdb/util/compression.h +49 -0
- package/deps/rocksdb/rocksdb/util/coro_utils.h +111 -0
- package/deps/rocksdb/rocksdb/util/single_thread_executor.h +55 -0
- package/deps/rocksdb/rocksdb.gyp +16 -15
- package/index.js +186 -3
- package/iterator.js +1 -0
- package/package-lock.json +23687 -0
- package/package.json +2 -30
- package/prebuilds/darwin-arm64/node.napi.node +0 -0
- package/deps/liburing/liburing/README +0 -46
- package/deps/liburing/liburing/test/232c93d07b74-test.c +0 -305
- package/deps/liburing/liburing/test/35fa71a030ca-test.c +0 -329
- package/deps/liburing/liburing/test/500f9fbadef8-test.c +0 -89
- package/deps/liburing/liburing/test/7ad0e4b2f83c-test.c +0 -93
- package/deps/liburing/liburing/test/8a9973408177-test.c +0 -106
- package/deps/liburing/liburing/test/917257daa0fe-test.c +0 -53
- package/deps/liburing/liburing/test/Makefile +0 -312
- package/deps/liburing/liburing/test/a0908ae19763-test.c +0 -58
- package/deps/liburing/liburing/test/a4c0b3decb33-test.c +0 -180
- package/deps/liburing/liburing/test/accept-link.c +0 -251
- package/deps/liburing/liburing/test/accept-reuse.c +0 -164
- package/deps/liburing/liburing/test/accept-test.c +0 -79
- package/deps/liburing/liburing/test/accept.c +0 -476
- package/deps/liburing/liburing/test/across-fork.c +0 -283
- package/deps/liburing/liburing/test/b19062a56726-test.c +0 -53
- package/deps/liburing/liburing/test/b5837bd5311d-test.c +0 -77
- package/deps/liburing/liburing/test/ce593a6c480a-test.c +0 -135
- package/deps/liburing/liburing/test/close-opath.c +0 -122
- package/deps/liburing/liburing/test/config +0 -10
- package/deps/liburing/liburing/test/connect.c +0 -398
- package/deps/liburing/liburing/test/cq-full.c +0 -96
- package/deps/liburing/liburing/test/cq-overflow.c +0 -294
- package/deps/liburing/liburing/test/cq-peek-batch.c +0 -102
- package/deps/liburing/liburing/test/cq-ready.c +0 -94
- package/deps/liburing/liburing/test/cq-size.c +0 -58
- package/deps/liburing/liburing/test/d4ae271dfaae-test.c +0 -96
- package/deps/liburing/liburing/test/d77a67ed5f27-test.c +0 -65
- package/deps/liburing/liburing/test/defer.c +0 -307
- package/deps/liburing/liburing/test/double-poll-crash.c +0 -186
- package/deps/liburing/liburing/test/eeed8b54e0df-test.c +0 -114
- package/deps/liburing/liburing/test/empty-eownerdead.c +0 -42
- package/deps/liburing/liburing/test/eventfd-disable.c +0 -151
- package/deps/liburing/liburing/test/eventfd-ring.c +0 -97
- package/deps/liburing/liburing/test/eventfd.c +0 -112
- package/deps/liburing/liburing/test/fadvise.c +0 -202
- package/deps/liburing/liburing/test/fallocate.c +0 -249
- package/deps/liburing/liburing/test/fc2a85cb02ef-test.c +0 -138
- package/deps/liburing/liburing/test/file-register.c +0 -843
- package/deps/liburing/liburing/test/file-update.c +0 -173
- package/deps/liburing/liburing/test/files-exit-hang-poll.c +0 -128
- package/deps/liburing/liburing/test/files-exit-hang-timeout.c +0 -134
- package/deps/liburing/liburing/test/fixed-link.c +0 -90
- package/deps/liburing/liburing/test/fsync.c +0 -224
- package/deps/liburing/liburing/test/hardlink.c +0 -136
- package/deps/liburing/liburing/test/helpers.c +0 -135
- package/deps/liburing/liburing/test/helpers.h +0 -67
- package/deps/liburing/liburing/test/io-cancel.c +0 -537
- package/deps/liburing/liburing/test/io_uring_enter.c +0 -296
- package/deps/liburing/liburing/test/io_uring_register.c +0 -664
- package/deps/liburing/liburing/test/io_uring_setup.c +0 -192
- package/deps/liburing/liburing/test/iopoll.c +0 -366
- package/deps/liburing/liburing/test/lfs-openat-write.c +0 -117
- package/deps/liburing/liburing/test/lfs-openat.c +0 -273
- package/deps/liburing/liburing/test/link-timeout.c +0 -1107
- package/deps/liburing/liburing/test/link.c +0 -496
- package/deps/liburing/liburing/test/link_drain.c +0 -229
- package/deps/liburing/liburing/test/madvise.c +0 -195
- package/deps/liburing/liburing/test/mkdir.c +0 -108
- package/deps/liburing/liburing/test/multicqes_drain.c +0 -383
- package/deps/liburing/liburing/test/nop-all-sizes.c +0 -107
- package/deps/liburing/liburing/test/nop.c +0 -115
- package/deps/liburing/liburing/test/open-close.c +0 -146
- package/deps/liburing/liburing/test/openat2.c +0 -240
- package/deps/liburing/liburing/test/personality.c +0 -204
- package/deps/liburing/liburing/test/pipe-eof.c +0 -81
- package/deps/liburing/liburing/test/pipe-reuse.c +0 -105
- package/deps/liburing/liburing/test/poll-cancel-ton.c +0 -139
- package/deps/liburing/liburing/test/poll-cancel.c +0 -135
- package/deps/liburing/liburing/test/poll-link.c +0 -227
- package/deps/liburing/liburing/test/poll-many.c +0 -208
- package/deps/liburing/liburing/test/poll-mshot-update.c +0 -273
- package/deps/liburing/liburing/test/poll-ring.c +0 -48
- package/deps/liburing/liburing/test/poll-v-poll.c +0 -353
- package/deps/liburing/liburing/test/poll.c +0 -109
- package/deps/liburing/liburing/test/probe.c +0 -137
- package/deps/liburing/liburing/test/read-write.c +0 -876
- package/deps/liburing/liburing/test/register-restrictions.c +0 -633
- package/deps/liburing/liburing/test/rename.c +0 -134
- package/deps/liburing/liburing/test/ring-leak.c +0 -173
- package/deps/liburing/liburing/test/ring-leak2.c +0 -249
- package/deps/liburing/liburing/test/rsrc_tags.c +0 -449
- package/deps/liburing/liburing/test/runtests-loop.sh +0 -16
- package/deps/liburing/liburing/test/runtests.sh +0 -170
- package/deps/liburing/liburing/test/rw_merge_test.c +0 -97
- package/deps/liburing/liburing/test/self.c +0 -91
- package/deps/liburing/liburing/test/send_recv.c +0 -291
- package/deps/liburing/liburing/test/send_recvmsg.c +0 -345
- package/deps/liburing/liburing/test/sendmsg_fs_cve.c +0 -198
- package/deps/liburing/liburing/test/shared-wq.c +0 -84
- package/deps/liburing/liburing/test/short-read.c +0 -75
- package/deps/liburing/liburing/test/shutdown.c +0 -163
- package/deps/liburing/liburing/test/sigfd-deadlock.c +0 -74
- package/deps/liburing/liburing/test/socket-rw-eagain.c +0 -156
- package/deps/liburing/liburing/test/socket-rw.c +0 -147
- package/deps/liburing/liburing/test/splice.c +0 -511
- package/deps/liburing/liburing/test/sq-full-cpp.cc +0 -45
- package/deps/liburing/liburing/test/sq-full.c +0 -45
- package/deps/liburing/liburing/test/sq-poll-dup.c +0 -200
- package/deps/liburing/liburing/test/sq-poll-kthread.c +0 -168
- package/deps/liburing/liburing/test/sq-poll-share.c +0 -137
- package/deps/liburing/liburing/test/sq-space_left.c +0 -159
- package/deps/liburing/liburing/test/sqpoll-cancel-hang.c +0 -159
- package/deps/liburing/liburing/test/sqpoll-disable-exit.c +0 -195
- package/deps/liburing/liburing/test/sqpoll-exit-hang.c +0 -77
- package/deps/liburing/liburing/test/sqpoll-sleep.c +0 -68
- package/deps/liburing/liburing/test/statx.c +0 -172
- package/deps/liburing/liburing/test/stdout.c +0 -232
- package/deps/liburing/liburing/test/submit-link-fail.c +0 -154
- package/deps/liburing/liburing/test/submit-reuse.c +0 -239
- package/deps/liburing/liburing/test/symlink.c +0 -116
- package/deps/liburing/liburing/test/teardowns.c +0 -58
- package/deps/liburing/liburing/test/thread-exit.c +0 -131
- package/deps/liburing/liburing/test/timeout-new.c +0 -246
- package/deps/liburing/liburing/test/timeout-overflow.c +0 -204
- package/deps/liburing/liburing/test/timeout.c +0 -1354
- package/deps/liburing/liburing/test/unlink.c +0 -111
- package/deps/liburing/liburing/test/wakeup-hang.c +0 -162
- package/deps/rocksdb/rocksdb/README.md +0 -32
- package/deps/rocksdb/rocksdb/microbench/README.md +0 -60
- package/deps/rocksdb/rocksdb/plugin/README.md +0 -43
- package/deps/rocksdb/rocksdb/port/README +0 -10
- package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/README +0 -13
- package/prebuilds/linux-x64/node.napi.node +0 -0
|
@@ -259,6 +259,9 @@ struct CompactionServiceInput {
|
|
|
259
259
|
std::vector<std::string> input_files;
|
|
260
260
|
int output_level;
|
|
261
261
|
|
|
262
|
+
// db_id is used to generate unique id of sst on the remote compactor
|
|
263
|
+
std::string db_id;
|
|
264
|
+
|
|
262
265
|
// information for subcompaction
|
|
263
266
|
bool has_begin = false;
|
|
264
267
|
std::string begin;
|
|
@@ -290,13 +293,15 @@ struct CompactionServiceOutputFile {
|
|
|
290
293
|
uint64_t file_creation_time;
|
|
291
294
|
uint64_t paranoid_hash;
|
|
292
295
|
bool marked_for_compaction;
|
|
296
|
+
UniqueId64x2 unique_id;
|
|
293
297
|
|
|
294
298
|
CompactionServiceOutputFile() = default;
|
|
295
299
|
CompactionServiceOutputFile(
|
|
296
300
|
const std::string& name, SequenceNumber smallest, SequenceNumber largest,
|
|
297
301
|
std::string _smallest_internal_key, std::string _largest_internal_key,
|
|
298
302
|
uint64_t _oldest_ancester_time, uint64_t _file_creation_time,
|
|
299
|
-
uint64_t _paranoid_hash, bool _marked_for_compaction
|
|
303
|
+
uint64_t _paranoid_hash, bool _marked_for_compaction,
|
|
304
|
+
UniqueId64x2 _unique_id)
|
|
300
305
|
: file_name(name),
|
|
301
306
|
smallest_seqno(smallest),
|
|
302
307
|
largest_seqno(largest),
|
|
@@ -305,7 +310,8 @@ struct CompactionServiceOutputFile {
|
|
|
305
310
|
oldest_ancester_time(_oldest_ancester_time),
|
|
306
311
|
file_creation_time(_file_creation_time),
|
|
307
312
|
paranoid_hash(_paranoid_hash),
|
|
308
|
-
marked_for_compaction(_marked_for_compaction)
|
|
313
|
+
marked_for_compaction(_marked_for_compaction),
|
|
314
|
+
unique_id(std::move(_unique_id)) {}
|
|
309
315
|
};
|
|
310
316
|
|
|
311
317
|
// CompactionServiceResult contains the compaction result from a different db
|
|
@@ -27,6 +27,7 @@
|
|
|
27
27
|
#include "rocksdb/options.h"
|
|
28
28
|
#include "rocksdb/write_buffer_manager.h"
|
|
29
29
|
#include "table/mock_table.h"
|
|
30
|
+
#include "table/unique_id_impl.h"
|
|
30
31
|
#include "test_util/testharness.h"
|
|
31
32
|
#include "test_util/testutil.h"
|
|
32
33
|
#include "util/string_util.h"
|
|
@@ -206,7 +207,7 @@ class CompactionJobTestBase : public testing::Test {
|
|
|
206
207
|
oldest_blob_file_number, kUnknownOldestAncesterTime,
|
|
207
208
|
kUnknownFileCreationTime, kUnknownFileChecksum,
|
|
208
209
|
kUnknownFileChecksumFuncName, kDisableUserTimestamp,
|
|
209
|
-
kDisableUserTimestamp);
|
|
210
|
+
kDisableUserTimestamp, kNullUniqueId64x2);
|
|
210
211
|
|
|
211
212
|
mutex_.Lock();
|
|
212
213
|
EXPECT_OK(
|
|
@@ -360,8 +361,8 @@ class CompactionJobTestBase : public testing::Test {
|
|
|
360
361
|
table_cache_, &event_logger, false, false, dbname_,
|
|
361
362
|
&compaction_job_stats_, Env::Priority::USER, nullptr /* IOTracer */,
|
|
362
363
|
/*manual_compaction_paused=*/nullptr,
|
|
363
|
-
/*manual_compaction_canceled=*/nullptr,
|
|
364
|
-
|
|
364
|
+
/*manual_compaction_canceled=*/nullptr, env_->GenerateUniqueId(),
|
|
365
|
+
DBImpl::GenerateDbSessionId(nullptr), full_history_ts_low_);
|
|
365
366
|
VerifyInitializationOfCompactionJobStats(compaction_job_stats_);
|
|
366
367
|
|
|
367
368
|
compaction_job.Prepare();
|
|
@@ -1254,13 +1255,14 @@ TEST_F(CompactionJobTest, ResultSerialization) {
|
|
|
1254
1255
|
result.status =
|
|
1255
1256
|
status_list.at(rnd.Uniform(static_cast<int>(status_list.size())));
|
|
1256
1257
|
while (!rnd.OneIn(10)) {
|
|
1258
|
+
UniqueId64x2 id{rnd64.Uniform(UINT64_MAX), rnd64.Uniform(UINT64_MAX)};
|
|
1257
1259
|
result.output_files.emplace_back(
|
|
1258
1260
|
rnd.RandomString(rnd.Uniform(kStrMaxLen)), rnd64.Uniform(UINT64_MAX),
|
|
1259
1261
|
rnd64.Uniform(UINT64_MAX),
|
|
1260
1262
|
rnd.RandomBinaryString(rnd.Uniform(kStrMaxLen)),
|
|
1261
1263
|
rnd.RandomBinaryString(rnd.Uniform(kStrMaxLen)),
|
|
1262
1264
|
rnd64.Uniform(UINT64_MAX), rnd64.Uniform(UINT64_MAX),
|
|
1263
|
-
rnd64.Uniform(UINT64_MAX), rnd.OneIn(2));
|
|
1265
|
+
rnd64.Uniform(UINT64_MAX), rnd.OneIn(2), id);
|
|
1264
1266
|
}
|
|
1265
1267
|
result.output_level = rnd.Uniform(10);
|
|
1266
1268
|
result.output_path = rnd.RandomString(rnd.Uniform(kStrMaxLen));
|
|
@@ -1288,6 +1290,16 @@ TEST_F(CompactionJobTest, ResultSerialization) {
|
|
|
1288
1290
|
ASSERT_FALSE(deserialized1.TEST_Equals(&result, &mismatch));
|
|
1289
1291
|
ASSERT_EQ(mismatch, "stats.num_input_files");
|
|
1290
1292
|
|
|
1293
|
+
// Test unique id mismatch
|
|
1294
|
+
if (!result.output_files.empty()) {
|
|
1295
|
+
CompactionServiceResult deserialized_tmp;
|
|
1296
|
+
ASSERT_OK(CompactionServiceResult::Read(output, &deserialized_tmp));
|
|
1297
|
+
deserialized_tmp.output_files[0].unique_id[0] += 1;
|
|
1298
|
+
ASSERT_FALSE(deserialized_tmp.TEST_Equals(&result, &mismatch));
|
|
1299
|
+
ASSERT_EQ(mismatch, "output_files.unique_id");
|
|
1300
|
+
deserialized_tmp.status.PermitUncheckedError();
|
|
1301
|
+
}
|
|
1302
|
+
|
|
1291
1303
|
// Test unknown field
|
|
1292
1304
|
CompactionServiceResult deserialized2;
|
|
1293
1305
|
output.clear();
|
|
@@ -12,6 +12,7 @@
|
|
|
12
12
|
#include "db/compaction/compaction_picker_level.h"
|
|
13
13
|
#include "db/compaction/compaction_picker_universal.h"
|
|
14
14
|
#include "db/compaction/file_pri.h"
|
|
15
|
+
#include "table/unique_id_impl.h"
|
|
15
16
|
#include "test_util/testharness.h"
|
|
16
17
|
#include "test_util/testutil.h"
|
|
17
18
|
#include "util/string_util.h"
|
|
@@ -115,7 +116,7 @@ class CompactionPickerTest : public testing::Test {
|
|
|
115
116
|
largest_seq, marked_for_compact, temperature, kInvalidBlobFileNumber,
|
|
116
117
|
kUnknownOldestAncesterTime, kUnknownFileCreationTime,
|
|
117
118
|
kUnknownFileChecksum, kUnknownFileChecksumFuncName,
|
|
118
|
-
kDisableUserTimestamp, kDisableUserTimestamp);
|
|
119
|
+
kDisableUserTimestamp, kDisableUserTimestamp, kNullUniqueId64x2);
|
|
119
120
|
f->compensated_file_size =
|
|
120
121
|
(compensated_file_size != 0) ? compensated_file_size : file_size;
|
|
121
122
|
f->oldest_ancester_time = oldest_ancestor_time;
|
|
@@ -288,6 +288,16 @@ TEST_F(CompactionServiceTest, BasicCompactions) {
|
|
|
288
288
|
auto s = static_cast<Status*>(status);
|
|
289
289
|
*s = Status::Aborted("MyTestCompactionService failed to compact!");
|
|
290
290
|
});
|
|
291
|
+
|
|
292
|
+
// tracking success unique id verification
|
|
293
|
+
std::atomic_int verify_passed{0};
|
|
294
|
+
SyncPoint::GetInstance()->SetCallBack(
|
|
295
|
+
"Version::VerifySstUniqueIds::Passed", [&](void* arg) {
|
|
296
|
+
// override job status
|
|
297
|
+
auto id = static_cast<std::string*>(arg);
|
|
298
|
+
assert(!id->empty());
|
|
299
|
+
verify_passed++;
|
|
300
|
+
});
|
|
291
301
|
SyncPoint::GetInstance()->EnableProcessing();
|
|
292
302
|
|
|
293
303
|
Status s;
|
|
@@ -312,6 +322,12 @@ TEST_F(CompactionServiceTest, BasicCompactions) {
|
|
|
312
322
|
}
|
|
313
323
|
}
|
|
314
324
|
ASSERT_TRUE(s.IsAborted());
|
|
325
|
+
|
|
326
|
+
// Test verification
|
|
327
|
+
ASSERT_EQ(verify_passed, 0);
|
|
328
|
+
options.verify_sst_unique_id_in_manifest = true;
|
|
329
|
+
Reopen(options);
|
|
330
|
+
ASSERT_GT(verify_passed, 0);
|
|
315
331
|
}
|
|
316
332
|
|
|
317
333
|
TEST_F(CompactionServiceTest, ManualCompaction) {
|