mirror of
https://source.quilibrium.com/quilibrium/ceremonyclient.git
synced 2024-11-20 15:15:18 +00:00
1237 lines
21 KiB
Plaintext
1237 lines
21 KiB
Plaintext
batch
|
|
set a 1
|
|
set b 2
|
|
----
|
|
|
|
compact a-b
|
|
----
|
|
6:
|
|
000005:[a#10,SET-b#11,SET]
|
|
|
|
batch
|
|
set c 3
|
|
set d 4
|
|
----
|
|
|
|
compact c-d
|
|
----
|
|
6:
|
|
000005:[a#10,SET-b#11,SET]
|
|
000007:[c#12,SET-d#13,SET]
|
|
|
|
batch
|
|
set b 5
|
|
set c 6
|
|
----
|
|
|
|
compact a-d
|
|
----
|
|
6:
|
|
000010:[a#0,SET-d#0,SET]
|
|
|
|
# This also tests flushing a memtable that only contains range
|
|
# deletions.
|
|
|
|
batch
|
|
del-range a e
|
|
----
|
|
|
|
compact a-d
|
|
----
|
|
|
|
# Test that a multi-output-file compaction generates non-overlapping files.
|
|
|
|
define target-file-sizes=(100, 1)
|
|
L0
|
|
b.SET.1:v
|
|
L0
|
|
a.SET.2:v
|
|
----
|
|
0.0:
|
|
000005:[a#2,SET-a#2,SET]
|
|
000004:[b#1,SET-b#1,SET]
|
|
|
|
compact a-b
|
|
----
|
|
1:
|
|
000006:[a#0,SET-a#0,SET]
|
|
000007:[b#0,SET-b#0,SET]
|
|
|
|
# A range tombstone extends past the grandparent file boundary used to limit the
|
|
# size of future compactions. Verify the range tombstone is split at that file
|
|
# boundary.
|
|
|
|
define target-file-sizes=(1, 1, 1, 1)
|
|
L1
|
|
a.SET.3:v
|
|
L2
|
|
a.RANGEDEL.2:e
|
|
L3
|
|
a.SET.0:v
|
|
b.SET.0:v
|
|
L3
|
|
c.SET.0:v
|
|
d.SET.0:v
|
|
----
|
|
1:
|
|
000004:[a#3,SET-a#3,SET]
|
|
2:
|
|
000005:[a#2,RANGEDEL-e#inf,RANGEDEL]
|
|
3:
|
|
000006:[a#0,SET-b#0,SET]
|
|
000007:[c#0,SET-d#0,SET]
|
|
|
|
wait-pending-table-stats
|
|
000005
|
|
----
|
|
num-entries: 1
|
|
num-deletions: 1
|
|
num-range-key-sets: 0
|
|
point-deletions-bytes-estimate: 0
|
|
range-deletions-bytes-estimate: 1552
|
|
|
|
compact a-e L1
|
|
----
|
|
2:
|
|
000008:[a#3,SET-c#inf,RANGEDEL]
|
|
000009:[c#2,RANGEDEL-e#inf,RANGEDEL]
|
|
3:
|
|
000006:[a#0,SET-b#0,SET]
|
|
000007:[c#0,SET-d#0,SET]
|
|
|
|
wait-pending-table-stats
|
|
000008
|
|
----
|
|
num-entries: 2
|
|
num-deletions: 1
|
|
num-range-key-sets: 0
|
|
point-deletions-bytes-estimate: 0
|
|
range-deletions-bytes-estimate: 776
|
|
|
|
# Same as above, except range tombstone covers multiple grandparent file boundaries.
|
|
|
|
define target-file-sizes=(1, 1, 1, 1) format-major-version=1
|
|
L1
|
|
a.SET.3:v
|
|
L2
|
|
a.RANGEDEL.2:g
|
|
L3
|
|
a.SET.0:v
|
|
b.SET.0:v
|
|
L3
|
|
c.SET.0:v
|
|
d.SET.0:v
|
|
L3
|
|
e.SET.0:v
|
|
f.SET.1:v
|
|
L3
|
|
f.SET.0:v
|
|
g.SET.0:v
|
|
----
|
|
1:
|
|
000004:[a#3,SET-a#3,SET]
|
|
2:
|
|
000005:[a#2,RANGEDEL-g#inf,RANGEDEL]
|
|
3:
|
|
000006:[a#0,SET-b#0,SET]
|
|
000007:[c#0,SET-d#0,SET]
|
|
000008:[e#0,SET-f#1,SET]
|
|
000009:[f#0,SET-g#0,SET]
|
|
|
|
compact a-e L1
|
|
----
|
|
2:
|
|
000010:[a#3,SET-c#inf,RANGEDEL]
|
|
000011:[c#2,RANGEDEL-e#inf,RANGEDEL]
|
|
000012:[e#2,RANGEDEL-f#inf,RANGEDEL]
|
|
000013:[f#2,RANGEDEL-g#inf,RANGEDEL]
|
|
3:
|
|
000006:[a#0,SET-b#0,SET]
|
|
000007:[c#0,SET-d#0,SET]
|
|
000008:[e#0,SET-f#1,SET]
|
|
000009:[f#0,SET-g#0,SET]
|
|
|
|
# A range tombstone covers multiple grandparent file boundaries between point keys,
|
|
# rather than after all point keys.
|
|
|
|
define target-file-sizes=(1, 1, 1, 1)
|
|
L1
|
|
a.SET.3:v
|
|
h.SET.3:v
|
|
L2
|
|
a.RANGEDEL.2:g
|
|
L3
|
|
a.SET.0:v
|
|
b.SET.0:v
|
|
L3
|
|
c.SET.0:v
|
|
d.SET.0:v
|
|
L3
|
|
e.SET.0:v
|
|
f.SET.1:v
|
|
----
|
|
1:
|
|
000004:[a#3,SET-h#3,SET]
|
|
2:
|
|
000005:[a#2,RANGEDEL-g#inf,RANGEDEL]
|
|
3:
|
|
000006:[a#0,SET-b#0,SET]
|
|
000007:[c#0,SET-d#0,SET]
|
|
000008:[e#0,SET-f#1,SET]
|
|
|
|
compact a-e L1
|
|
----
|
|
2:
|
|
000009:[a#3,SET-c#inf,RANGEDEL]
|
|
000010:[c#2,RANGEDEL-h#3,SET]
|
|
3:
|
|
000006:[a#0,SET-b#0,SET]
|
|
000007:[c#0,SET-d#0,SET]
|
|
000008:[e#0,SET-f#1,SET]
|
|
|
|
# A range tombstone is the first and only item output by a compaction, and it
|
|
# extends past the grandparent file boundary used to limit the size of future
|
|
# compactions. Verify the range tombstone is split at that file boundary.
|
|
|
|
define target-file-sizes=(1, 1, 1, 1)
|
|
L1
|
|
a.RANGEDEL.3:e
|
|
L2
|
|
a.SET.2:v
|
|
L3
|
|
a.SET.0:v
|
|
b.SET.0:v
|
|
L3
|
|
c.SET.0:v
|
|
d.SET.0:v
|
|
----
|
|
1:
|
|
000004:[a#3,RANGEDEL-e#inf,RANGEDEL]
|
|
2:
|
|
000005:[a#2,SET-a#2,SET]
|
|
3:
|
|
000006:[a#0,SET-b#0,SET]
|
|
000007:[c#0,SET-d#0,SET]
|
|
|
|
compact a-e L1
|
|
----
|
|
2:
|
|
000008:[a#3,RANGEDEL-c#inf,RANGEDEL]
|
|
000009:[c#3,RANGEDEL-e#inf,RANGEDEL]
|
|
3:
|
|
000006:[a#0,SET-b#0,SET]
|
|
000007:[c#0,SET-d#0,SET]
|
|
|
|
# An elided range tombstone is the first item encountered by a compaction,
|
|
# and the grandparent limit set by it extends to the next item, also a range
|
|
# tombstone. The first item should be elided, and the second item should
|
|
# reset the grandparent limit.
|
|
|
|
define target-file-sizes=(100, 100, 100, 100)
|
|
L1
|
|
a.RANGEDEL.4:d
|
|
L1
|
|
grandparent.RANGEDEL.2:z
|
|
h.SET.3:v
|
|
L2
|
|
grandparent.SET.1:v
|
|
L3
|
|
grandparent.SET.0:v
|
|
L3
|
|
m.SET.0:v
|
|
----
|
|
1:
|
|
000004:[a#4,RANGEDEL-d#inf,RANGEDEL]
|
|
000005:[grandparent#2,RANGEDEL-z#inf,RANGEDEL]
|
|
2:
|
|
000006:[grandparent#1,SET-grandparent#1,SET]
|
|
3:
|
|
000007:[grandparent#0,SET-grandparent#0,SET]
|
|
000008:[m#0,SET-m#0,SET]
|
|
|
|
compact a-h L1
|
|
----
|
|
2:
|
|
000009:[grandparent#2,RANGEDEL-m#inf,RANGEDEL]
|
|
000010:[m#2,RANGEDEL-z#inf,RANGEDEL]
|
|
3:
|
|
000007:[grandparent#0,SET-grandparent#0,SET]
|
|
000008:[m#0,SET-m#0,SET]
|
|
|
|
# Setup such that grandparent overlap limit is exceeded multiple times at the same user key ("b").
|
|
# Ensures the compaction output files are non-overlapping.
|
|
|
|
define target-file-sizes=(1, 1, 1, 1)
|
|
L1
|
|
a.SET.2:v
|
|
c.SET.2:v
|
|
L2
|
|
a.RANGEDEL.3:c
|
|
L3
|
|
b.SET.2:v
|
|
L3
|
|
b.SET.1:v
|
|
L3
|
|
b.SET.0:v
|
|
----
|
|
1:
|
|
000004:[a#2,SET-c#2,SET]
|
|
2:
|
|
000005:[a#3,RANGEDEL-c#inf,RANGEDEL]
|
|
3:
|
|
000006:[b#2,SET-b#2,SET]
|
|
000007:[b#1,SET-b#1,SET]
|
|
000008:[b#0,SET-b#0,SET]
|
|
|
|
compact a-c L1
|
|
----
|
|
2:
|
|
000009:[a#3,RANGEDEL-b#inf,RANGEDEL]
|
|
000010:[b#3,RANGEDEL-c#2,SET]
|
|
3:
|
|
000006:[b#2,SET-b#2,SET]
|
|
000007:[b#1,SET-b#1,SET]
|
|
000008:[b#0,SET-b#0,SET]
|
|
|
|
# Regression test for a bug where compaction would stop process range
|
|
# tombstones for an input level upon finding an sstable in the input
|
|
# level with no range tombstones. In the scenario below, sstable 6
|
|
# does not contain any range tombstones while sstable 7 does. Both are
|
|
# compacted together with sstable 5.
|
|
|
|
reset
|
|
----
|
|
|
|
batch
|
|
set a 1
|
|
set b 1
|
|
set c 1
|
|
set d 1
|
|
set z 1
|
|
----
|
|
|
|
compact a-z
|
|
----
|
|
6:
|
|
000005:[a#10,SET-z#14,SET]
|
|
|
|
build ext1
|
|
set a 2
|
|
----
|
|
|
|
build ext2
|
|
set b 2
|
|
del-range c z
|
|
----
|
|
|
|
ingest ext1 ext2
|
|
----
|
|
0.0:
|
|
000006:[a#15,SET-a#15,SET]
|
|
000007:[b#16,SET-z#inf,RANGEDEL]
|
|
6:
|
|
000005:[a#10,SET-z#14,SET]
|
|
|
|
iter
|
|
first
|
|
next
|
|
next
|
|
next
|
|
----
|
|
a: (2, .)
|
|
b: (2, .)
|
|
z: (1, .)
|
|
.
|
|
|
|
compact a-z
|
|
----
|
|
6:
|
|
000008:[a#0,SET-z#0,SET]
|
|
|
|
iter
|
|
first
|
|
next
|
|
next
|
|
next
|
|
----
|
|
a: (2, .)
|
|
b: (2, .)
|
|
z: (1, .)
|
|
.
|
|
|
|
# Regresion test for a bug in sstable smallest boundary generation
|
|
# where the smallest key for an sstable was set to a key "larger" than
|
|
# the start key of the first range tombstone. This in turn fouled up
|
|
# the processing logic of range tombstones used by mergingIter which
|
|
# allowed stepping out of an sstable even though it contained a range
|
|
# tombstone that covered keys in lower levels.
|
|
|
|
define target-file-sizes=(1, 1, 1, 1)
|
|
L0
|
|
c.SET.4:4
|
|
L1
|
|
a.SET.3:3
|
|
L2
|
|
a.RANGEDEL.2:e
|
|
L3
|
|
b.SET.1:1
|
|
----
|
|
0.0:
|
|
000004:[c#4,SET-c#4,SET]
|
|
1:
|
|
000005:[a#3,SET-a#3,SET]
|
|
2:
|
|
000006:[a#2,RANGEDEL-e#inf,RANGEDEL]
|
|
3:
|
|
000007:[b#1,SET-b#1,SET]
|
|
|
|
compact a-e L1
|
|
----
|
|
0.0:
|
|
000004:[c#4,SET-c#4,SET]
|
|
2:
|
|
000008:[a#3,SET-b#inf,RANGEDEL]
|
|
000009:[b#2,RANGEDEL-e#inf,RANGEDEL]
|
|
3:
|
|
000007:[b#1,SET-b#1,SET]
|
|
|
|
# We should only see a:3 and c:4 at this point.
|
|
|
|
iter
|
|
first
|
|
next
|
|
next
|
|
----
|
|
a: (3, .)
|
|
c: (4, .)
|
|
.
|
|
|
|
# The bug allowed seeing b:1 during reverse iteration.
|
|
|
|
iter
|
|
last
|
|
prev
|
|
prev
|
|
----
|
|
c: (4, .)
|
|
a: (3, .)
|
|
.
|
|
|
|
# This is a similar scenario to the one above. In older versions of Pebble this
|
|
# case necessitated adjusting the seqnum of the range tombstone to
|
|
# prev.LargestKey.SeqNum-1. We no longer allow user keys to be split across
|
|
# sstables, and the seqnum adjustment is no longer necessary.
|
|
#
|
|
# Note the target-file-size of 26 is specially tailored to get the
|
|
# desired compaction output.
|
|
|
|
define target-file-sizes=(26, 26, 26, 26) snapshots=(1, 2, 3)
|
|
L1
|
|
a.SET.4:4
|
|
L1
|
|
b.SET.2:2
|
|
b.RANGEDEL.3:e
|
|
L3
|
|
b.SET.1:1
|
|
----
|
|
1:
|
|
000004:[a#4,SET-a#4,SET]
|
|
000005:[b#3,RANGEDEL-e#inf,RANGEDEL]
|
|
3:
|
|
000006:[b#1,SET-b#1,SET]
|
|
|
|
compact a-e L1
|
|
----
|
|
2:
|
|
000007:[a#4,SET-a#4,SET]
|
|
000008:[b#3,RANGEDEL-e#inf,RANGEDEL]
|
|
3:
|
|
000006:[b#1,SET-b#1,SET]
|
|
|
|
iter
|
|
first
|
|
next
|
|
last
|
|
prev
|
|
----
|
|
a: (4, .)
|
|
.
|
|
a: (4, .)
|
|
.
|
|
|
|
# Similar to the preceding scenario, except the range tombstone has
|
|
# the same seqnum as the largest key in the preceding file.
|
|
|
|
define target-file-sizes=(26, 26, 26, 26) snapshots=(1, 2, 3)
|
|
L1
|
|
a.SET.4:4
|
|
L1
|
|
b.SET.3:3
|
|
b.RANGEDEL.3:e
|
|
L3
|
|
b.SET.1:1
|
|
----
|
|
1:
|
|
000004:[a#4,SET-a#4,SET]
|
|
000005:[b#3,RANGEDEL-e#inf,RANGEDEL]
|
|
3:
|
|
000006:[b#1,SET-b#1,SET]
|
|
|
|
compact a-e L1
|
|
----
|
|
2:
|
|
000007:[a#4,SET-a#4,SET]
|
|
000008:[b#3,RANGEDEL-e#inf,RANGEDEL]
|
|
3:
|
|
000006:[b#1,SET-b#1,SET]
|
|
|
|
iter
|
|
first
|
|
next
|
|
next
|
|
last
|
|
prev
|
|
prev
|
|
----
|
|
a: (4, .)
|
|
b: (3, .)
|
|
.
|
|
b: (3, .)
|
|
a: (4, .)
|
|
.
|
|
|
|
# Similar to the preceding scenario, except the range tombstone has
|
|
# a smaller seqnum than the largest key in the preceding file.
|
|
|
|
define target-file-sizes=(26, 26, 26, 26) snapshots=(1, 2, 3)
|
|
L1
|
|
a.SET.4:4
|
|
L1
|
|
b.SET.4:4
|
|
b.RANGEDEL.2:e
|
|
L3
|
|
b.SET.1:1
|
|
----
|
|
1:
|
|
000004:[a#4,SET-a#4,SET]
|
|
000005:[b#4,SET-e#inf,RANGEDEL]
|
|
3:
|
|
000006:[b#1,SET-b#1,SET]
|
|
|
|
compact a-e L1
|
|
----
|
|
2:
|
|
000007:[a#4,SET-a#4,SET]
|
|
000008:[b#4,SET-e#inf,RANGEDEL]
|
|
3:
|
|
000006:[b#1,SET-b#1,SET]
|
|
|
|
iter
|
|
first
|
|
next
|
|
next
|
|
last
|
|
prev
|
|
prev
|
|
----
|
|
a: (4, .)
|
|
b: (4, .)
|
|
.
|
|
b: (4, .)
|
|
a: (4, .)
|
|
.
|
|
|
|
# Test a scenario where the last point key in an sstable has a seqnum
|
|
# of 0.
|
|
|
|
define target-file-sizes=(1, 1, 26) snapshots=(2)
|
|
L1
|
|
a.SET.3:3
|
|
b.RANGEDEL.3:e
|
|
b.SET.0:0
|
|
L3
|
|
a.RANGEDEL.2:b
|
|
L3
|
|
c.SET.0:0
|
|
d.SET.0:0
|
|
----
|
|
1:
|
|
000004:[a#3,SET-e#inf,RANGEDEL]
|
|
3:
|
|
000005:[a#2,RANGEDEL-b#inf,RANGEDEL]
|
|
000006:[c#0,SET-d#0,SET]
|
|
|
|
iter
|
|
last
|
|
prev
|
|
----
|
|
a: (3, .)
|
|
.
|
|
|
|
compact a-e L1
|
|
----
|
|
2:
|
|
000007:[a#3,SET-c#inf,RANGEDEL]
|
|
000008:[c#3,RANGEDEL-e#inf,RANGEDEL]
|
|
3:
|
|
000005:[a#2,RANGEDEL-b#inf,RANGEDEL]
|
|
000006:[c#0,SET-d#0,SET]
|
|
|
|
iter
|
|
last
|
|
prev
|
|
----
|
|
a: (3, .)
|
|
.
|
|
|
|
# Test a scenario where the last point key in an sstable before the
|
|
# grandparent limit is reached has a seqnum of 0. We want to cut the
|
|
# sstable after the next point key is added, rather than continuing to
|
|
# add keys indefinitely (or till the size limit is reached).
|
|
|
|
define target-file-sizes=(100, 1, 52) snapshots=(2)
|
|
L1
|
|
a.SET.3:3
|
|
b.RANGEDEL.3:e
|
|
b.SET.0:0
|
|
c.SET.3:1
|
|
d.SET.1:1
|
|
L3
|
|
c.RANGEDEL.2:d
|
|
----
|
|
1:
|
|
000004:[a#3,SET-e#inf,RANGEDEL]
|
|
3:
|
|
000005:[c#2,RANGEDEL-d#inf,RANGEDEL]
|
|
|
|
compact a-f L1
|
|
----
|
|
2:
|
|
000006:[a#3,SET-c#inf,RANGEDEL]
|
|
000007:[c#3,RANGEDEL-e#inf,RANGEDEL]
|
|
3:
|
|
000005:[c#2,RANGEDEL-d#inf,RANGEDEL]
|
|
|
|
# Test a scenario where we the last point key in an sstable has a
|
|
# seqnum of 0, but there is another range tombstone later in the
|
|
# compaction. This scenario was previously triggering an assertion due
|
|
# to the rangedel.Fragmenter being finished prematurely.
|
|
|
|
define target-file-sizes=(1, 1, 1)
|
|
L1
|
|
a.SET.0:0
|
|
c.RANGEDEL.1:d
|
|
L3
|
|
b.SET.0:0
|
|
----
|
|
1:
|
|
000004:[a#0,SET-d#inf,RANGEDEL]
|
|
3:
|
|
000005:[b#0,SET-b#0,SET]
|
|
|
|
compact a-e L1
|
|
----
|
|
2:
|
|
000006:[a#0,SET-a#0,SET]
|
|
3:
|
|
000005:[b#0,SET-b#0,SET]
|
|
|
|
define target-file-sizes=(1, 1, 1, 1)
|
|
L0
|
|
b.SET.1:v
|
|
L0
|
|
a.SET.2:v
|
|
----
|
|
0.0:
|
|
000005:[a#2,SET-a#2,SET]
|
|
000004:[b#1,SET-b#1,SET]
|
|
|
|
add-ongoing-compaction startLevel=0 outputLevel=1 start=a end=b
|
|
----
|
|
|
|
async-compact a-b L0
|
|
----
|
|
manual compaction blocked until ongoing finished
|
|
1:
|
|
000006:[a#0,SET-a#0,SET]
|
|
000007:[b#0,SET-b#0,SET]
|
|
|
|
compact a-b L1
|
|
----
|
|
2:
|
|
000008:[a#0,SET-a#0,SET]
|
|
000009:[b#0,SET-b#0,SET]
|
|
|
|
add-ongoing-compaction startLevel=0 outputLevel=1 start=a end=b
|
|
----
|
|
|
|
async-compact a-b L2
|
|
----
|
|
manual compaction blocked until ongoing finished
|
|
3:
|
|
000010:[a#0,SET-a#0,SET]
|
|
000011:[b#0,SET-b#0,SET]
|
|
|
|
add-ongoing-compaction startLevel=0 outputLevel=1 start=a end=b
|
|
----
|
|
|
|
set-concurrent-compactions num=2
|
|
----
|
|
|
|
async-compact a-b L3
|
|
----
|
|
manual compaction did not block for ongoing
|
|
4:
|
|
000012:[a#0,SET-a#0,SET]
|
|
000013:[b#0,SET-b#0,SET]
|
|
|
|
remove-ongoing-compaction
|
|
----
|
|
|
|
add-ongoing-compaction startLevel=4 outputLevel=5 start=a end=b
|
|
----
|
|
|
|
async-compact a-b L4
|
|
----
|
|
manual compaction blocked until ongoing finished
|
|
5:
|
|
000014:[a#0,SET-a#0,SET]
|
|
000015:[b#0,SET-b#0,SET]
|
|
|
|
# Test of a scenario where consecutive elided range tombstones and grandparent
|
|
# boundaries could result in an invariant violation in the rangedel fragmenter.
|
|
|
|
define target-file-sizes=(1, 1, 1, 1)
|
|
L1
|
|
a.RANGEDEL.4:b
|
|
c.RANGEDEL.4:d
|
|
e.RANGEDEL.4:f
|
|
L1
|
|
g.RANGEDEL.6:h
|
|
i.RANGEDEL.4:j
|
|
L1
|
|
k.RANGEDEL.5:q
|
|
m.RANGEDEL.4:q
|
|
L2
|
|
a.SET.2:foo
|
|
L3
|
|
a.SET.1:foo
|
|
c.SET.1:foo
|
|
L3
|
|
ff.SET.1:v
|
|
L3
|
|
k.SET.1:foo
|
|
----
|
|
1:
|
|
000004:[a#4,RANGEDEL-f#inf,RANGEDEL]
|
|
000005:[g#6,RANGEDEL-j#inf,RANGEDEL]
|
|
000006:[k#5,RANGEDEL-q#inf,RANGEDEL]
|
|
2:
|
|
000007:[a#2,SET-a#2,SET]
|
|
3:
|
|
000008:[a#1,SET-c#1,SET]
|
|
000009:[ff#1,SET-ff#1,SET]
|
|
000010:[k#1,SET-k#1,SET]
|
|
|
|
compact a-q L1
|
|
----
|
|
2:
|
|
000011:[a#4,RANGEDEL-d#inf,RANGEDEL]
|
|
000012:[k#5,RANGEDEL-m#inf,RANGEDEL]
|
|
3:
|
|
000008:[a#1,SET-c#1,SET]
|
|
000009:[ff#1,SET-ff#1,SET]
|
|
000010:[k#1,SET-k#1,SET]
|
|
|
|
# Test a case where a new output file is started, there are no previous output
|
|
# files, there are no additional keys (key = nil) and the rangedel fragmenter
|
|
# is non-empty.
|
|
define target-file-sizes=(1, 1, 1)
|
|
L1
|
|
a.RANGEDEL.10:b
|
|
d.RANGEDEL.9:e
|
|
q.RANGEDEL.8:r
|
|
L2
|
|
g.RANGEDEL.7:h
|
|
L3
|
|
q.SET.6:6
|
|
----
|
|
1:
|
|
000004:[a#10,RANGEDEL-r#inf,RANGEDEL]
|
|
2:
|
|
000005:[g#7,RANGEDEL-h#inf,RANGEDEL]
|
|
3:
|
|
000006:[q#6,SET-q#6,SET]
|
|
|
|
compact a-r L1
|
|
----
|
|
2:
|
|
000007:[q#8,RANGEDEL-r#inf,RANGEDEL]
|
|
3:
|
|
000006:[q#6,SET-q#6,SET]
|
|
|
|
define target-file-sizes=(100, 100, 100)
|
|
L1
|
|
a.RANGEDEL.10:b
|
|
b.SET.0:foo
|
|
d.RANGEDEL.0:e
|
|
j.SET.10:foo
|
|
L2
|
|
f.RANGEDEL.7:g
|
|
L3
|
|
c.SET.6:6
|
|
L3
|
|
c.SET.5:5
|
|
L3
|
|
c.SET.4:4
|
|
L4
|
|
a.SET.0:0
|
|
f.SET.0:0
|
|
----
|
|
1:
|
|
000004:[a#10,RANGEDEL-j#10,SET]
|
|
2:
|
|
000005:[f#7,RANGEDEL-g#inf,RANGEDEL]
|
|
3:
|
|
000006:[c#6,SET-c#6,SET]
|
|
000007:[c#5,SET-c#5,SET]
|
|
000008:[c#4,SET-c#4,SET]
|
|
4:
|
|
000009:[a#0,SET-f#0,SET]
|
|
|
|
compact a-r L1
|
|
----
|
|
2:
|
|
000010:[a#10,RANGEDEL-b#0,SET]
|
|
000011:[d#0,RANGEDEL-j#10,SET]
|
|
3:
|
|
000006:[c#6,SET-c#6,SET]
|
|
000007:[c#5,SET-c#5,SET]
|
|
000008:[c#4,SET-c#4,SET]
|
|
4:
|
|
000009:[a#0,SET-f#0,SET]
|
|
|
|
# Test a snapshot that separates a range deletion from all the data that it
|
|
# deletes. Ensure that we respect the target-file-size and split into multiple
|
|
# outputs.
|
|
|
|
define target-file-sizes=(1, 1, 1) snapshots=(14)
|
|
L1
|
|
a.RANGEDEL.15:z
|
|
b.SET.11:foo
|
|
c.SET.11:foo
|
|
L2
|
|
c.SET.0:foo
|
|
d.SET.0:foo
|
|
----
|
|
1:
|
|
000004:[a#15,RANGEDEL-z#inf,RANGEDEL]
|
|
2:
|
|
000005:[c#0,SET-d#0,SET]
|
|
|
|
sstable-properties file=000004
|
|
snapshot-pinned-keys
|
|
----
|
|
snapshot-pinned-keys:
|
|
pebble.num.snapshot-pinned-keys: 2
|
|
pebble.raw.snapshot-pinned-keys.size: 18
|
|
|
|
compact a-z L1
|
|
----
|
|
2:
|
|
000006:[a#15,RANGEDEL-c#inf,RANGEDEL]
|
|
000007:[c#15,RANGEDEL-d#inf,RANGEDEL]
|
|
000008:[d#15,RANGEDEL-z#inf,RANGEDEL]
|
|
|
|
sstable-properties file=000006
|
|
snapshot-pinned-keys
|
|
----
|
|
snapshot-pinned-keys:
|
|
pebble.num.snapshot-pinned-keys: 1
|
|
pebble.raw.snapshot-pinned-keys.size: 9
|
|
|
|
sstable-properties file=000007
|
|
snapshot-pinned-keys
|
|
----
|
|
snapshot-pinned-keys:
|
|
pebble.num.snapshot-pinned-keys: 1
|
|
pebble.raw.snapshot-pinned-keys.size: 9
|
|
|
|
sstable-properties file=000008
|
|
snapshot-pinned-keys
|
|
----
|
|
snapshot-pinned-keys:
|
|
pebble.num.snapshot-pinned-keys: 1
|
|
pebble.raw.snapshot-pinned-keys.size: 9
|
|
|
|
# Test an interaction between a range deletion that will be elided with
|
|
# output splitting. Ensure that the output is still split (previous versions
|
|
# of the code did not, because of intricacies around preventing a zero
|
|
# sequence number in an output's largest key).
|
|
|
|
define target-file-sizes=(1, 1, 1)
|
|
L1
|
|
a.RANGEDEL.10:z
|
|
b.SET.11:foo
|
|
c.SET.11:foo
|
|
L2
|
|
c.SET.0:foo
|
|
d.SET.0:foo
|
|
----
|
|
1:
|
|
000004:[a#10,RANGEDEL-z#inf,RANGEDEL]
|
|
2:
|
|
000005:[c#0,SET-d#0,SET]
|
|
|
|
compact a-z L1
|
|
----
|
|
2:
|
|
000006:[b#0,SET-b#0,SET]
|
|
000007:[c#0,SET-c#0,SET]
|
|
|
|
define target-file-sizes=(1, 1, 1, 1)
|
|
L0
|
|
a.SET.3:v
|
|
b.SET.2:v
|
|
L2
|
|
a.SET.1:v
|
|
L3
|
|
a.SET.0:v
|
|
b.SET.0:v
|
|
L3
|
|
c.SET.0:v
|
|
----
|
|
0.0:
|
|
000004:[a#3,SET-b#2,SET]
|
|
2:
|
|
000005:[a#1,SET-a#1,SET]
|
|
3:
|
|
000006:[a#0,SET-b#0,SET]
|
|
000007:[c#0,SET-c#0,SET]
|
|
|
|
set-concurrent-compactions num=3
|
|
----
|
|
|
|
compact a-c parallel hide-file-num
|
|
----
|
|
4:
|
|
[a#0,SET-a#0,SET]
|
|
[b#0,SET-b#0,SET]
|
|
[c#0,SET-c#0,SET]
|
|
|
|
define target-file-sizes=(1, 1, 1, 1)
|
|
L0
|
|
a.SET.3:v
|
|
b.SET.2:v
|
|
L0
|
|
a.SET.2:v
|
|
c.SET.2:v
|
|
L2
|
|
a.SET.1:v
|
|
b.SET.1:v
|
|
L2
|
|
c.SET.1:v
|
|
L2
|
|
d.SET.0:v
|
|
L3
|
|
a.SET.0:v
|
|
b.SET.0:v
|
|
L3
|
|
c.SET.0:v
|
|
----
|
|
0.1:
|
|
000004:[a#3,SET-b#2,SET]
|
|
0.0:
|
|
000005:[a#2,SET-c#2,SET]
|
|
2:
|
|
000006:[a#1,SET-b#1,SET]
|
|
000007:[c#1,SET-c#1,SET]
|
|
000008:[d#0,SET-d#0,SET]
|
|
3:
|
|
000009:[a#0,SET-b#0,SET]
|
|
000010:[c#0,SET-c#0,SET]
|
|
|
|
set-concurrent-compactions num=2
|
|
----
|
|
|
|
compact a-c L0 parallel
|
|
----
|
|
1:
|
|
000011:[a#3,SET-a#3,SET]
|
|
000012:[b#2,SET-b#2,SET]
|
|
000013:[c#2,SET-c#2,SET]
|
|
2:
|
|
000006:[a#1,SET-b#1,SET]
|
|
000007:[c#1,SET-c#1,SET]
|
|
000008:[d#0,SET-d#0,SET]
|
|
3:
|
|
000009:[a#0,SET-b#0,SET]
|
|
000010:[c#0,SET-c#0,SET]
|
|
|
|
add-ongoing-compaction startLevel=3 outputLevel=4 start=a end=d
|
|
----
|
|
|
|
# We allow 2 maximum concurrent compactions. The operation below generates
|
|
# 2 concurrent compactions (a-b, c) from L1 to L2. With 1 ongoing compaction with
|
|
# output level L4, there is no conflict and thus the concurrent compactions should
|
|
# be queued up and executed sequentially. We ensure that the compactions finish and
|
|
# that the final result of the compactions is correct.
|
|
|
|
async-compact a-d L1 parallel
|
|
----
|
|
manual compaction did not block for ongoing
|
|
2:
|
|
000014:[a#3,SET-a#3,SET]
|
|
000015:[b#2,SET-b#2,SET]
|
|
000016:[c#2,SET-c#2,SET]
|
|
000008:[d#0,SET-d#0,SET]
|
|
3:
|
|
000009:[a#0,SET-b#0,SET]
|
|
000010:[c#0,SET-c#0,SET]
|
|
|
|
remove-ongoing-compaction
|
|
----
|
|
|
|
set-concurrent-compactions num=3
|
|
----
|
|
|
|
compact a-d parallel hide-file-num
|
|
----
|
|
4:
|
|
[a#0,SET-a#0,SET]
|
|
[b#0,SET-b#0,SET]
|
|
[c#0,SET-c#0,SET]
|
|
[d#0,SET-d#0,SET]
|
|
|
|
# Create a contrived compaction that forces point key and rangedel iterators
|
|
# to stay in sync to emit a correct view of visible and deleted keys. Note that
|
|
# Pebble no longer produces range tombstones that go outside a file's bounds,
|
|
# but past versions of pebble did, and we should still be able to handle those
|
|
# well.
|
|
|
|
define target-file-sizes=(1, 1, 1, 1, 1, 1) snapshots=(390)
|
|
L3 start=tmgc.MERGE.391 end=tmgc.MERGE.391
|
|
tmgc.MERGE.391:foo
|
|
tmgc.RANGEDEL.331:udkatvs
|
|
L3 start=tmgc.MERGE.384 end=tmgc.MERGE.384
|
|
tmgc.MERGE.384:bar
|
|
tmgc.RANGEDEL.383:tvsalezade
|
|
tmgc.RANGEDEL.331:tvsalezade
|
|
L3 start=tmgc.RANGEDEL.383 end=tvsalezade.RANGEDEL.72057594037927935
|
|
tmgc.RANGEDEL.383:tvsalezade
|
|
tmgc.SET.375:baz
|
|
tmgc.RANGEDEL.356:tvsalezade
|
|
----
|
|
3:
|
|
000004:[tmgc#391,MERGE-tmgc#391,MERGE]
|
|
000005:[tmgc#384,MERGE-tmgc#384,MERGE]
|
|
000006:[tmgc#383,RANGEDEL-tvsalezade#inf,RANGEDEL]
|
|
|
|
compact a-z L3
|
|
----
|
|
4:
|
|
000007:[tmgc#391,MERGE-tmgc#384,MERGE]
|
|
|
|
# baz should NOT be visible in the value.
|
|
|
|
iter
|
|
first
|
|
next
|
|
next
|
|
----
|
|
tmgc: (barfoo, .)
|
|
.
|
|
.
|
|
|
|
# Test split user keys containing RANGEDELs.
|
|
# Note that this manual compaction is multilevel!
|
|
|
|
define
|
|
L4
|
|
b.SET.10:b10
|
|
L5 start=b.SET.9 end=b.SET.8
|
|
b.SET.9:b9
|
|
b.SET.8:b8
|
|
b.RANGEDEL.1:z
|
|
L5 start=b.SET.7 end=b.SET.6
|
|
b.SET.7:b7
|
|
b.SET.6:b6
|
|
b.RANGEDEL.1:z
|
|
L5 start=b.SET.5 end=z.RANGEDEL.72057594037927935
|
|
b.SET.5:b5
|
|
b.SET.4:b4
|
|
b.RANGEDEL.1:z
|
|
L6
|
|
b.SET.0:b0
|
|
bat.SET.0:bat
|
|
cat.SET.0:cat
|
|
----
|
|
4:
|
|
000004:[b#10,SET-b#10,SET]
|
|
5:
|
|
000005:[b#9,SET-b#8,SET]
|
|
000006:[b#7,SET-b#6,SET]
|
|
000007:[b#5,SET-z#inf,RANGEDEL]
|
|
6:
|
|
000008:[b#0,SET-cat#0,SET]
|
|
|
|
compact a-z
|
|
----
|
|
6:
|
|
000009:[b#0,SET-b#0,SET]
|
|
|
|
iter
|
|
first
|
|
next
|
|
----
|
|
b: (b10, .)
|
|
.
|
|
|
|
# Ensure an untruncated range tombstone (eg, written by an earlier version of
|
|
# Pebble, Cockroach v21.2 or earlier) cannot delete newer keys outside the
|
|
# containing file's bounds.
|
|
#
|
|
# Regression test for cockroachdb/cockroach#89777.
|
|
|
|
define target-file-sizes=(1)
|
|
L5 start=g.RANGEDEL.1 end=z.RANGEDEL.72057594037927935
|
|
a.RANGEDEL.1:z
|
|
m.SET.1:bar
|
|
L6
|
|
m.SET.0:bax
|
|
L6 start=a.SET.1 end=g.RANGEDEL.72057594037927935
|
|
a.SET.1:foo
|
|
a.RANGEDEL.1:z
|
|
----
|
|
5:
|
|
000004:[g#1,RANGEDEL-z#inf,RANGEDEL]
|
|
6:
|
|
000006:[a#1,SET-g#inf,RANGEDEL]
|
|
000005:[m#0,SET-m#0,SET]
|
|
|
|
# Compacting g-z should result in the elision of the range tombstone in the g-z
|
|
# span.
|
|
|
|
compact g-z
|
|
----
|
|
6:
|
|
000006:[a#1,SET-g#inf,RANGEDEL]
|
|
000007:[m#0,SET-m#0,SET]
|
|
|
|
# Write a bunch of keys within the keyspace [g,z), and flush them.
|
|
|
|
batch
|
|
set b b
|
|
set h h
|
|
set i i
|
|
set j j
|
|
set k k
|
|
set m m
|
|
set q q
|
|
set y y
|
|
----
|
|
|
|
flush
|
|
----
|
|
0.0:
|
|
000009:[b#10,SET-b#10,SET]
|
|
000010:[h#11,SET-h#11,SET]
|
|
000011:[i#12,SET-i#12,SET]
|
|
000012:[j#13,SET-j#13,SET]
|
|
000013:[k#14,SET-k#14,SET]
|
|
000014:[m#15,SET-m#15,SET]
|
|
000015:[q#16,SET-q#16,SET]
|
|
000016:[y#17,SET-y#17,SET]
|
|
6:
|
|
000006:[a#1,SET-g#inf,RANGEDEL]
|
|
000007:[m#0,SET-m#0,SET]
|
|
|
|
# Compact g-z to zero the sequence numbers of the newer keys.
|
|
|
|
compact g-z
|
|
----
|
|
0.0:
|
|
000009:[b#10,SET-b#10,SET]
|
|
6:
|
|
000006:[a#1,SET-g#inf,RANGEDEL]
|
|
000048:[h#0,SET-k#0,SET]
|
|
000049:[m#0,SET-y#0,SET]
|
|
|
|
batch
|
|
set t t
|
|
----
|
|
|
|
flush
|
|
----
|
|
0.0:
|
|
000009:[b#10,SET-b#10,SET]
|
|
000051:[t#18,SET-t#18,SET]
|
|
6:
|
|
000006:[a#1,SET-g#inf,RANGEDEL]
|
|
000048:[h#0,SET-k#0,SET]
|
|
000049:[m#0,SET-y#0,SET]
|
|
|
|
# Compact everything. The batch-committed keys with zeroed sequence numbers (eg,
|
|
# h, i, j, k, m, q, y) should all still exist because the a-z tombstone in
|
|
# 000006 should be limited in how far it expands.
|
|
|
|
compact a-z
|
|
----
|
|
6:
|
|
000062:[a#0,SET-i#0,SET]
|
|
000063:[j#0,SET-q#0,SET]
|
|
000064:[t#0,SET-y#0,SET]
|
|
|
|
iter
|
|
first
|
|
next
|
|
next
|
|
next
|
|
next
|
|
next
|
|
next
|
|
next
|
|
next
|
|
next
|
|
----
|
|
a: (foo, .)
|
|
b: (b, .)
|
|
h: (h, .)
|
|
i: (i, .)
|
|
j: (j, .)
|
|
k: (k, .)
|
|
m: (m, .)
|
|
q: (q, .)
|
|
t: (t, .)
|
|
y: (y, .)
|
|
|
|
# Ensure an untruncated range tombstone (eg, written by an earlier version of
|
|
# Pebble, Cockroach v21.2 or earlier) cannot expand beyond its previous
|
|
# truncated bounds.
|
|
#
|
|
# Regression test for cockroachdb/cockroach#89777.
|
|
|
|
define snapshots=(2)
|
|
L5 start=g.RANGEDEL.3 end=n.RANGEDEL.72057594037927935
|
|
a.RANGEDEL.3:z
|
|
m.SET.1:bar
|
|
L5
|
|
s.SET.0:bax
|
|
L6
|
|
q.SET.0:foo
|
|
----
|
|
5:
|
|
000004:[g#3,RANGEDEL-n#inf,RANGEDEL]
|
|
000005:[s#0,SET-s#0,SET]
|
|
6:
|
|
000006:[q#0,SET-q#0,SET]
|
|
|
|
# Compacting all the files in a single expansion should not expand the
|
|
# untruncated range tombstone to the larger untruncated bounds. The rangedel
|
|
# should remain bounded as [a,n).
|
|
|
|
compact a-z
|
|
----
|
|
6:
|
|
000007:[g#3,RANGEDEL-s#0,SET]
|