# 1 memtable.

define
mem
  a.SET.10:b
  a.SET.12:c
  a.SET.14:d
  b.MERGE.10:b
  b.MERGE.12:c
  b.MERGE.14:d
  b.RANGEDEL.15:c
  b.MERGE.16:e
  c.SET.10:b
  c.SET.12:c
  c.SET.14:d
----
mem: 1

get seq=11
a
b
c
----
a:b
b:b
c:b

get seq=13
a
b
c
----
a:c
b:bc
c:c

get seq=15
a
b
c
----
a:d
b:bcd
c:d

get seq=16
a
b
c
----
a:d
b: pebble: not found
c:d

get seq=17
a
b
c
----
a:d
b:e
c:d

get seq=15
a
b
c
----
a:d
b:bcd
c:d

iter seq=15
first
next
next
next
seek-ge a
seek-ge b
seek-ge c
seek-ge d
last
prev
prev
prev
seek-lt a
seek-lt b
seek-lt c
seek-lt d
----
a: (d, .)
b: (bcd, .)
c: (d, .)
.
a: (d, .)
b: (bcd, .)
c: (d, .)
.
c: (d, .)
b: (bcd, .)
a: (d, .)
.
.
a: (d, .)
b: (bcd, .)
c: (d, .)

iter seq=16
first
next
next
seek-ge a
seek-ge b
seek-ge c
seek-ge d
last
prev
prev
seek-lt a
seek-lt b
seek-lt c
seek-lt d
----
a: (d, .)
c: (d, .)
.
a: (d, .)
c: (d, .)
c: (d, .)
.
c: (d, .)
a: (d, .)
.
.
a: (d, .)
a: (d, .)
c: (d, .)

# Multiple memtables.

define
mem
  a.SET.10:b
  b.MERGE.10:b
  c.SET.10:b
mem
  a.SET.12:c
  b.MERGE.12:c
  c.SET.12:c
mem
  a.SET.14:d
  b.MERGE.14:d
  c.SET.14:d
mem
  b.RANGEDEL.15:c
mem
  b.MERGE.16:e
----
mem: 5

get seq=11
a
b
c
----
a:b
b:b
c:b

get seq=13
a
b
c
----
a:c
b:bc
c:c

get seq=15
a
b
c
----
a:d
b:bcd
c:d

get seq=16
a
b
c
----
a:d
b: pebble: not found
c:d

get seq=17
a
b
c
----
a:d
b:e
c:d

get seq=15
a
b
c
----
a:d
b:bcd
c:d

iter seq=15
first
next
next
next
seek-ge a
seek-ge b
seek-ge c
seek-ge d
last
prev
prev
prev
seek-lt a
seek-lt b
seek-lt c
seek-lt d
----
a: (d, .)
b: (bcd, .)
c: (d, .)
.
a: (d, .)
b: (bcd, .)
c: (d, .)
.
c: (d, .)
b: (bcd, .)
a: (d, .)
.
.
a: (d, .)
b: (bcd, .)
c: (d, .)

iter seq=16
first
next
next
seek-ge a
seek-ge b
seek-ge c
seek-ge d
last
prev
prev
seek-lt a
seek-lt b
seek-lt c
seek-lt d
----
a: (d, .)
c: (d, .)
.
a: (d, .)
c: (d, .)
c: (d, .)
.
c: (d, .)
a: (d, .)
.
.
a: (d, .)
a: (d, .)
c: (d, .)

# Overlapping range deletions in the same memtable.

define
mem
  a.SET.10:1
  a.SET.12:2
  a.SET.14:3
  a.SET.16:4
  b.SET.10:1
  b.SET.12:2
  b.SET.14:3
  b.SET.16:4
  c.SET.10:1
  c.SET.12:2
  c.SET.14:3
  c.SET.16:4
  d.SET.10:1
  d.SET.12:2
  d.SET.14:3
  d.SET.16:4
  a.RANGEDEL.11:b
  b.RANGEDEL.13:c
  b.RANGEDEL.11:c
  c.RANGEDEL.15:d
  c.RANGEDEL.13:d
  c.RANGEDEL.11:d
----
mem: 1

get seq=11
a
b
c
d
----
a:1
b:1
c:1
d:1

get seq=12
a
b
c
d
----
a: pebble: not found
b: pebble: not found
c: pebble: not found
d:1

get seq=14
a
b
c
d
----
a:2
b: pebble: not found
c: pebble: not found
d:2

get seq=16
a
b
c
d
----
a:3
b:3
c: pebble: not found
d:3

get seq=18
a
b
c
d
----
a:4
b:4
c:4
d:4

iter seq=11
first
next
next
next
next
last
prev
prev
prev
prev
----
a: (1, .)
b: (1, .)
c: (1, .)
d: (1, .)
.
d: (1, .)
c: (1, .)
b: (1, .)
a: (1, .)
.

iter seq=12
first
next
last
prev
----
d: (1, .)
.
d: (1, .)
.

iter seq=14
first
next
next
last
prev
prev
----
a: (2, .)
d: (2, .)
.
d: (2, .)
a: (2, .)
.

iter seq=16
first
next
next
next
last
prev
prev
prev
----
a: (3, .)
b: (3, .)
d: (3, .)
.
d: (3, .)
b: (3, .)
a: (3, .)
.

iter seq=18
first
next
next
next
next
last
prev
prev
prev
prev
----
a: (4, .)
b: (4, .)
c: (4, .)
d: (4, .)
.
d: (4, .)
c: (4, .)
b: (4, .)
a: (4, .)
.

# Overlapping range deletions in different memtables. Note that the
# range tombstones are not fragmented in this case.

define
mem
  a.SET.10:1
  b.SET.10:1
  c.SET.10:1
  d.SET.10:1
mem
  a.SET.12:2
  b.SET.12:2
  c.SET.12:2
  d.SET.12:2
  a.RANGEDEL.11:d
mem
  a.SET.14:3
  b.SET.14:3
  c.SET.14:3
  d.SET.14:3
  b.RANGEDEL.13:d
mem
  a.SET.16:4
  b.SET.16:4
  c.SET.16:4
  d.SET.16:4
  c.RANGEDEL.13:d
----
mem: 4

get seq=11
a
b
c
d
----
a:1
b:1
c:1
d:1

get seq=12
a
b
c
d
----
a: pebble: not found
b: pebble: not found
c: pebble: not found
d:1

get seq=14
a
b
c
d
----
a:2
b: pebble: not found
c: pebble: not found
d:2

get seq=16
a
b
c
d
----
a:3
b:3
c: pebble: not found
d:3

get seq=18
a
b
c
d
----
a:4
b:4
c:4
d:4

iter seq=11
first
next
next
next
next
last
prev
prev
prev
prev
----
a: (1, .)
b: (1, .)
c: (1, .)
d: (1, .)
.
d: (1, .)
c: (1, .)
b: (1, .)
a: (1, .)
.

iter seq=12
first
next
last
prev
----
d: (1, .)
.
d: (1, .)
.

iter seq=14
first
next
next
last
prev
prev
----
a: (2, .)
d: (2, .)
.
d: (2, .)
a: (2, .)
.

iter seq=16
first
next
next
next
last
prev
prev
prev
----
a: (3, .)
b: (3, .)
d: (3, .)
.
d: (3, .)
b: (3, .)
a: (3, .)
.

iter seq=18
first
next
next
next
next
last
prev
prev
prev
prev
----
a: (4, .)
b: (4, .)
c: (4, .)
d: (4, .)
.
d: (4, .)
c: (4, .)
b: (4, .)
a: (4, .)
.

# User-key spread across multiple levels.

define
mem
  a.MERGE.13:4
L1
  a.MERGE.12:3
L2
  a.MERGE.11:2
L3
  a.MERGE.10:1
----
mem: 1
L1:
  000004:[a#12,MERGE-a#12,MERGE]
L2:
  000005:[a#11,MERGE-a#11,MERGE]
L3:
  000006:[a#10,MERGE-a#10,MERGE]

get seq=10
a
----
a: pebble: not found

get seq=11
a
----
a:1

get seq=12
a
----
a:12

get seq=13
a
----
a:123

get seq=14
a
----
a:1234

iter seq=11
first
seek-ge a
seek-ge b
last
seek-lt a
seek-lt b
----
a: (1, .)
a: (1, .)
.
a: (1, .)
.
a: (1, .)

iter seq=12
first
seek-ge a
seek-ge b
last
seek-lt a
seek-lt b
----
a: (12, .)
a: (12, .)
.
a: (12, .)
.
a: (12, .)

iter seq=13
first
seek-ge a
seek-ge b
last
seek-lt a
seek-lt b
----
a: (123, .)
a: (123, .)
.
a: (123, .)
.
a: (123, .)

iter seq=14
first
seek-ge a
seek-ge b
last
seek-lt a
seek-lt b
----
a: (1234, .)
a: (1234, .)
.
a: (1234, .)
.
a: (1234, .)

# Range deletions on multiple levels.
define
L0
  a.SET.13:4
  b.SET.13:4
  d.SET.13:4
  c.RANGEDEL.13:d
L1
  a.SET.12:3
  d.SET.12:3
  b.RANGEDEL.12:d
L2
  d.SET.11:2
  a.RANGEDEL.11:d
L3
  a.SET.10:1
  b.SET.10:1
  c.SET.10:1
  d.SET.10:1
----
mem: 1
L0.0:
  000004:[a#13,SET-d#13,SET]
L1:
  000005:[a#12,SET-d#12,SET]
L2:
  000006:[a#11,RANGEDEL-d#11,SET]
L3:
  000007:[a#10,SET-d#10,SET]

get seq=11
a
b
c
d
----
a:1
b:1
c:1
d:1

get seq=12
a
b
c
d
----
a: pebble: not found
b: pebble: not found
c: pebble: not found
d:2

get seq=13
a
b
c
d
----
a:3
b: pebble: not found
c: pebble: not found
d:3

get seq=14
a
b
c
d
----
a:4
b:4
c: pebble: not found
d:4

iter seq=11
first
next
next
next
last
prev
prev
prev
----
a: (1, .)
b: (1, .)
c: (1, .)
d: (1, .)
d: (1, .)
c: (1, .)
b: (1, .)
a: (1, .)

iter seq=12
first
last
----
d: (2, .)
d: (2, .)

iter seq=13
first
next
last
prev
----
a: (3, .)
d: (3, .)
d: (3, .)
a: (3, .)

iter seq=14
first
next
next
last
prev
prev
----
a: (4, .)
b: (4, .)
d: (4, .)
d: (4, .)
b: (4, .)
a: (4, .)

# Range deletions spanning tables within a level.

define
mem
  a.SET.12:3
  b.SET.12:3
  c.SET.12:3
  d.SET.12:3
L1
  a.RANGEDEL.11:b
L1
  b.RANGEDEL.11:c
L1
  c.RANGEDEL.11:d
L2
  a.SET.10:1
  b.SET.10:1
  c.SET.10:1
  d.SET.10:1
----
mem: 1
L1:
  000004:[a#11,RANGEDEL-b#inf,RANGEDEL]
  000005:[b#11,RANGEDEL-c#inf,RANGEDEL]
  000006:[c#11,RANGEDEL-d#inf,RANGEDEL]
L2:
  000007:[a#10,SET-d#10,SET]

get seq=11
a
b
c
d
----
a:1
b:1
c:1
d:1

get seq=12
a
b
c
d
----
a: pebble: not found
b: pebble: not found
c: pebble: not found
d:1

get seq=13
a
b
c
d
----
a:3
b:3
c:3
d:3

iter seq=11
first
next
next
next
last
prev
prev
prev
----
a: (1, .)
b: (1, .)
c: (1, .)
d: (1, .)
d: (1, .)
c: (1, .)
b: (1, .)
a: (1, .)

iter seq=12
first
last
----
d: (1, .)
d: (1, .)

iter seq=13
first
next
next
next
last
prev
prev
prev
----
a: (3, .)
b: (3, .)
c: (3, .)
d: (3, .)
d: (3, .)
c: (3, .)
b: (3, .)
a: (3, .)

# Invalid LSM structure (range deletion at newer level covers newer
# write at an older level). This LSM structure is not generated
# naturally, but tested here to show the level-by-level nature of Get.

define
L1
  a.RANGEDEL.10:b
L2
  a.SET.11:2
----
mem: 1
L1:
  000004:[a#10,RANGEDEL-b#inf,RANGEDEL]
L2:
  000005:[a#11,SET-a#11,SET]

get seq=12
a
----
a: pebble: not found

# A range tombstone straddles two SSTs. One is compacted to a lower level. Its
# keys that are newer than the range tombstone should not disappear.
#
# Uses a snapshot to prevent range tombstone from being elided when it gets
# compacted to the bottommost level.

define target-file-sizes=(100, 1) snapshots=(1)
L0
  a.RANGEDEL.10:e
L0
  a.SET.11:v
L0
  c.SET.12:v
----
mem: 1
L0.1:
  000005:[a#11,SET-a#11,SET]
  000006:[c#12,SET-c#12,SET]
L0.0:
  000004:[a#10,RANGEDEL-e#inf,RANGEDEL]

compact a-e
----
L1:
  000007:[a#11,SET-c#inf,RANGEDEL]
  000008:[c#12,SET-e#inf,RANGEDEL]

compact d-e
----
L1:
  000007:[a#11,SET-c#inf,RANGEDEL]
L2:
  000008:[c#12,SET-e#inf,RANGEDEL]

iter seq=13
seek-ge b
next
----
c: (v, .)
.

# Reverse the above test: compact the left file containing the split range
# tombstone downwards, and iterate from right to left.

define target-file-sizes=(100, 1) snapshots=(1)
L0
  a.RANGEDEL.10:e
L0
  a.SET.11:v
L0
  c.SET.12:v
----
mem: 1
L0.1:
  000005:[a#11,SET-a#11,SET]
  000006:[c#12,SET-c#12,SET]
L0.0:
  000004:[a#10,RANGEDEL-e#inf,RANGEDEL]

compact a-e
----
L1:
  000007:[a#11,SET-c#inf,RANGEDEL]
  000008:[c#12,SET-e#inf,RANGEDEL]

compact a-b
----
L1:
  000008:[c#12,SET-e#inf,RANGEDEL]
L2:
  000007:[a#11,SET-c#inf,RANGEDEL]

iter seq=13
seek-lt d
prev
prev
----
c: (v, .)
a: (v, .)
.

# A range tombstone straddles two sstables. One is compacted two
# levels lower. The other is compacted one level lower. The one that
# is compacted one level lower should not see its boundaries expand
# causing it to delete more keys. A snapshot is used to prevent range
# tombstone from being elided when it gets compacted to the bottommost
# level.

define target-file-sizes=(100, 1) snapshots=(1)
L0
  a.RANGEDEL.10:e
L0
  a.SET.11:v
L0
  c.SET.12:v
L2
  d.SET.0:v
----
mem: 1
L0.1:
  000005:[a#11,SET-a#11,SET]
  000006:[c#12,SET-c#12,SET]
L0.0:
  000004:[a#10,RANGEDEL-e#inf,RANGEDEL]
L2:
  000007:[d#0,SET-d#0,SET]

compact a-b
----
L1:
  000008:[a#11,SET-c#inf,RANGEDEL]
  000009:[c#12,SET-d#inf,RANGEDEL]
  000010:[d#10,RANGEDEL-e#inf,RANGEDEL]
L2:
  000007:[d#0,SET-d#0,SET]

compact d-e
----
L1:
  000008:[a#11,SET-c#inf,RANGEDEL]
  000009:[c#12,SET-d#inf,RANGEDEL]
L3:
  000011:[d#10,RANGEDEL-e#inf,RANGEDEL]

get seq=13
c
----
c:v

compact a-b L1
----
L1:
  000009:[c#12,SET-d#inf,RANGEDEL]
L2:
  000008:[a#11,SET-c#inf,RANGEDEL]
L3:
  000011:[d#10,RANGEDEL-e#inf,RANGEDEL]

get seq=13
c
----
c:v

# A slight variation on the scenario above where a range tombstone is
# expanded past the boundaries of its "atomic compaction unit".

define target-file-sizes=(100, 1) snapshots=(1)
L0
  a.RANGEDEL.10:e
L0
  a.SET.11:v
L0
  c.SET.12:v
L0
  f.SET.13:v
L2
  d.SET.0:v
----
mem: 1
L0.1:
  000005:[a#11,SET-a#11,SET]
  000006:[c#12,SET-c#12,SET]
L0.0:
  000004:[a#10,RANGEDEL-e#inf,RANGEDEL]
  000007:[f#13,SET-f#13,SET]
L2:
  000008:[d#0,SET-d#0,SET]

compact a-b
----
L0.0:
  000007:[f#13,SET-f#13,SET]
L1:
  000009:[a#11,SET-c#inf,RANGEDEL]
  000010:[c#12,SET-d#inf,RANGEDEL]
  000011:[d#10,RANGEDEL-e#inf,RANGEDEL]
L2:
  000008:[d#0,SET-d#0,SET]

compact d-e
----
L0.0:
  000007:[f#13,SET-f#13,SET]
L1:
  000009:[a#11,SET-c#inf,RANGEDEL]
  000010:[c#12,SET-d#inf,RANGEDEL]
L3:
  000012:[d#10,RANGEDEL-e#inf,RANGEDEL]

get seq=13
c
----
c:v

compact f-f L0
----
L1:
  000009:[a#11,SET-c#inf,RANGEDEL]
  000010:[c#12,SET-d#inf,RANGEDEL]
  000007:[f#13,SET-f#13,SET]
L3:
  000012:[d#10,RANGEDEL-e#inf,RANGEDEL]

compact a-f L1
----
L2:
  000013:[a#11,SET-c#inf,RANGEDEL]
  000014:[c#12,SET-d#inf,RANGEDEL]
  000015:[f#13,SET-f#13,SET]
L3:
  000012:[d#10,RANGEDEL-e#inf,RANGEDEL]

get seq=13
c
----
c:v

define
L0
  a.RANGEDEL.12:f
L0
  a.RANGEDEL.13:c
  c.RANGEDEL.13:f
L1
  b.RANGEDEL.11:e
L2
  c.RANGEDEL.10:d
----
mem: 1
L0.1:
  000005:[a#13,RANGEDEL-f#inf,RANGEDEL]
L0.0:
  000004:[a#12,RANGEDEL-f#inf,RANGEDEL]
L1:
  000006:[b#11,RANGEDEL-e#inf,RANGEDEL]
L2:
  000007:[c#10,RANGEDEL-d#inf,RANGEDEL]

wait-pending-table-stats
000007
----
num-entries: 1
num-deletions: 1
num-range-key-sets: 0
point-deletions-bytes-estimate: 0
range-deletions-bytes-estimate: 0

wait-pending-table-stats
000006
----
num-entries: 1
num-deletions: 1
num-range-key-sets: 0
point-deletions-bytes-estimate: 0
range-deletions-bytes-estimate: 601

wait-pending-table-stats
000004
----
num-entries: 1
num-deletions: 1
num-range-key-sets: 0
point-deletions-bytes-estimate: 0
range-deletions-bytes-estimate: 1202

wait-pending-table-stats
000005
----
num-entries: 2
num-deletions: 2
num-range-key-sets: 0
point-deletions-bytes-estimate: 0
range-deletions-bytes-estimate: 1202


# Range deletions with varying overlap.
define
L0
  a.SET.13:4
  b.SET.13:4
  d.SET.13:4
  c.RANGEDEL.13:d
L1
  a.SET.12:3
  d.SET.12:3
  b.RANGEDEL.12:d
L2
  d.SET.11:2
  a.RANGEDEL.11:d
L3
  a.SET.10:1
  b.SET.10:1
  c.SET.10:1
  d.SET.10:1
----
mem: 1
L0.0:
  000004:[a#13,SET-d#13,SET]
L1:
  000005:[a#12,SET-d#12,SET]
L2:
  000006:[a#11,RANGEDEL-d#11,SET]
L3:
  000007:[a#10,SET-d#10,SET]

wait-pending-table-stats
000007
----
num-entries: 4
num-deletions: 0
num-range-key-sets: 0
point-deletions-bytes-estimate: 0
range-deletions-bytes-estimate: 0

wait-pending-table-stats
000006
----
num-entries: 2
num-deletions: 1
num-range-key-sets: 0
point-deletions-bytes-estimate: 0
range-deletions-bytes-estimate: 42

wait-pending-table-stats
000005
----
num-entries: 3
num-deletions: 1
num-range-key-sets: 0
point-deletions-bytes-estimate: 0
range-deletions-bytes-estimate: 68

wait-pending-table-stats
000004
----
num-entries: 4
num-deletions: 1
num-range-key-sets: 0
point-deletions-bytes-estimate: 0
range-deletions-bytes-estimate: 100

# Multiple Range deletions in a table.
define
L0
  a.RANGEDEL.15:d
  e.RANGEDEL.15:z
L0
  a.RANGEDEL.14:d
L0
  e.RANGEDEL.13:z
L1
  a.SET.11:1
  b.SET.11:1
  c.SET.11:1
L2
  x.SET.10:2
----
mem: 1
L0.1:
  000004:[a#15,RANGEDEL-z#inf,RANGEDEL]
L0.0:
  000005:[a#14,RANGEDEL-d#inf,RANGEDEL]
  000006:[e#13,RANGEDEL-z#inf,RANGEDEL]
L1:
  000007:[a#11,SET-c#11,SET]
L2:
  000008:[x#10,SET-x#10,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: 573

wait-pending-table-stats
000006
----
num-entries: 1
num-deletions: 1
num-range-key-sets: 0
point-deletions-bytes-estimate: 0
range-deletions-bytes-estimate: 562

wait-pending-table-stats
000004
----
num-entries: 2
num-deletions: 2
num-range-key-sets: 0
point-deletions-bytes-estimate: 0
range-deletions-bytes-estimate: 1135

define
L1
  a.RANGEDEL.11:d
  a.MERGE.11:1
  a.SET.10:2
  b.SET.11:1
  c.SET.11:1
----
mem: 1
L1:
  000004:[a#11,RANGEDEL-d#inf,RANGEDEL]

get seq=12
a
----
a:1
