-
Notifications
You must be signed in to change notification settings - Fork 3.8k
/
Copy pathprotectedts
145 lines (120 loc) · 3.86 KB
/
protectedts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
reconcile
----
mutations discard
----
# Write a protected timestamp record on the cluster.
protect record-id=1 ts=1
cluster
----
# Write a protected timestamp record on the system tenant keyspace, and on the
# secondary tenant keyspace.
protect record-id=2 ts=2
tenants 1,2
----
mutations
----
upsert {entire-keyspace} protection_policies=[{ts: 1}]
upsert {source=1,target=1} protection_policies=[{ts: 2}]
upsert {source=1,target=2} protection_policies=[{ts: 2}]
exec-sql
CREATE DATABASE db;
CREATE TABLE db.t1();
CREATE TABLE db.t2();
----
mutations
----
upsert /Table/10{6-7} range default
upsert /Table/10{7-8} range default
# Write a protected timestamp record on each table.
protect record-id=3 ts=3
descs 106,107
----
mutations
----
delete /Table/10{6-7}
upsert /Table/10{6-7} protection_policies=[{ts: 3}]
delete /Table/10{7-8}
upsert /Table/10{7-8} protection_policies=[{ts: 3}]
# Write a protected timestamp record on the database to ensure
# it applies to the tables in the database.
protect record-id=4 ts=4
descs 104
----
mutations
----
delete /Table/10{6-7}
upsert /Table/10{6-7} protection_policies=[{ts: 3} {ts: 4}]
delete /Table/10{7-8}
upsert /Table/10{7-8} protection_policies=[{ts: 3} {ts: 4}]
# Write a protected timestamp record on the entire keyspace.
protect record-id=5 ts=5
cluster
----
mutations
----
delete {entire-keyspace}
upsert {entire-keyspace} protection_policies=[{ts: 1} {ts: 5}]
state limit=3
----
{entire-keyspace} protection_policies=[{ts: 1} {ts: 5}]
{source=1,target=1} protection_policies=[{ts: 2}]
{source=1,target=2} protection_policies=[{ts: 2}]
...
state offset=51
----
...
/Table/4{8-9} database system (host)
/Table/5{0-1} database system (host)
/Table/5{1-2} database system (host)
/Table/5{2-3} database system (host)
/Table/5{3-4} database system (host)
/Table/5{4-5} database system (host)
/Table/5{5-6} database system (host)
/Table/5{6-7} database system (host)
/Table/5{7-8} ttl_seconds=3600 ignore_strict_gc=true num_replicas=5 rangefeed_enabled=true
/Table/10{6-7} protection_policies=[{ts: 3} {ts: 4}]
/Table/10{7-8} protection_policies=[{ts: 3} {ts: 4}]
# Release the cluster records.
release record-id=5
----
mutations
----
delete {entire-keyspace}
upsert {entire-keyspace} protection_policies=[{ts: 1}]
release record-id=1
----
# At this point there are no cluster target protected timestamp records, and so we should only see
# a delete entry.
mutations
----
delete {entire-keyspace}
state limit=2
----
{source=1,target=1} protection_policies=[{ts: 2}]
{source=1,target=2} protection_policies=[{ts: 2}]
...
# Release the tenant records.
release record-id=2
----
# At this point there are no tenant target protected timestamp records on the
# system tenant, or secondary tenant and so we should only see delete entries.
mutations
----
delete {source=1,target=1}
delete {source=1,target=2}
state limit=2
----
/{Min-System/NodeLiveness} ttl_seconds=3600 num_replicas=5
/System/NodeLiveness{-Max} ttl_seconds=600 num_replicas=5
...
# Release the schema object records.
release record-id=3
----
release record-id=4
----
mutations
----
delete /Table/10{6-7}
upsert /Table/10{6-7} range default
delete /Table/10{7-8}
upsert /Table/10{7-8} range default