-
Notifications
You must be signed in to change notification settings - Fork 69
/
Copy pathoptions_test.go
458 lines (325 loc) · 15.7 KB
/
options_test.go
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
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
package grocksdb
import (
"testing"
"github.com/stretchr/testify/require"
)
func TestOptions(t *testing.T) {
t.Parallel()
wbm := NewWriteBufferManager(123456, true)
defer wbm.Destroy()
opts := NewDefaultOptions()
defer opts.Destroy()
cto := NewCuckooTableOptions()
opts.SetCuckooTableFactory(cto)
require.EqualValues(t, PointInTimeRecovery, opts.GetWALRecoveryMode())
opts.SetWALRecoveryMode(SkipAnyCorruptedRecordsRecovery)
require.EqualValues(t, SkipAnyCorruptedRecordsRecovery, opts.GetWALRecoveryMode())
require.EqualValues(t, 2, opts.GetMaxBackgroundJobs())
opts.SetMaxBackgroundJobs(10)
require.EqualValues(t, 10, opts.GetMaxBackgroundJobs())
opts.SetMaxBackgroundCompactions(9)
require.EqualValues(t, 9, opts.GetMaxBackgroundCompactions())
opts.SetMaxBackgroundFlushes(8)
require.EqualValues(t, 8, opts.GetMaxBackgroundFlushes())
opts.SetMaxLogFileSize(1 << 30)
require.EqualValues(t, 1<<30, opts.GetMaxLogFileSize())
opts.SetLogFileTimeToRoll(924)
require.EqualValues(t, 924, opts.GetLogFileTimeToRoll())
opts.SetKeepLogFileNum(19)
require.EqualValues(t, 19, opts.GetKeepLogFileNum())
opts.SetRecycleLogFileNum(81)
require.EqualValues(t, 81, opts.GetRecycleLogFileNum())
opts.SetSoftPendingCompactionBytesLimit(50 << 18)
require.EqualValues(t, 50<<18, opts.GetSoftPendingCompactionBytesLimit())
opts.SetHardPendingCompactionBytesLimit(50 << 19)
require.EqualValues(t, 50<<19, opts.GetHardPendingCompactionBytesLimit())
require.EqualValues(t, uint64(0x40000000), opts.GetMaxManifestFileSize())
opts.SetMaxManifestFileSize(23 << 10)
require.EqualValues(t, 23<<10, opts.GetMaxManifestFileSize())
opts.SetTableCacheNumshardbits(5)
require.EqualValues(t, 5, opts.GetTableCacheNumshardbits())
opts.SetArenaBlockSize(9 << 20)
require.EqualValues(t, 9<<20, opts.GetArenaBlockSize())
opts.SetUseFsync(true)
require.EqualValues(t, true, opts.UseFsync())
opts.SetLevelCompactionDynamicLevelBytes(true)
require.EqualValues(t, true, opts.GetLevelCompactionDynamicLevelBytes())
opts.SetWALTtlSeconds(52)
require.EqualValues(t, 52, opts.GetWALTtlSeconds())
opts.SetWalSizeLimitMb(540)
require.EqualValues(t, 540, opts.GetWalSizeLimitMb())
require.EqualValues(t, 4<<20, opts.GetManifestPreallocationSize())
opts.SetManifestPreallocationSize(5 << 10)
require.EqualValues(t, 5<<10, opts.GetManifestPreallocationSize())
opts.SetAllowMmapReads(true)
require.EqualValues(t, true, opts.AllowMmapReads())
require.EqualValues(t, false, opts.AllowMmapWrites())
opts.SetAllowMmapWrites(true)
require.EqualValues(t, true, opts.AllowMmapWrites())
opts.SetUseDirectReads(true)
require.EqualValues(t, true, opts.UseDirectReads())
opts.SetUseDirectIOForFlushAndCompaction(true)
require.EqualValues(t, true, opts.UseDirectIOForFlushAndCompaction())
opts.SetIsFdCloseOnExec(true)
require.EqualValues(t, true, opts.IsFdCloseOnExec())
opts.SetStatsDumpPeriodSec(79)
require.EqualValues(t, 79, opts.GetStatsDumpPeriodSec())
opts.SetStatsPersistPeriodSec(97)
require.EqualValues(t, 97, opts.GetStatsPersistPeriodSec())
opts.SetAdviseRandomOnOpen(true)
require.EqualValues(t, true, opts.AdviseRandomOnOpen())
// opts.SetAccessHintOnCompactionStart(SequentialCompactionAccessPattern)
// require.EqualValues(t, SequentialCompactionAccessPattern, opts.GetAccessHintOnCompactionStart())
opts.SetDbWriteBufferSize(1 << 30)
require.EqualValues(t, 1<<30, opts.GetDbWriteBufferSize())
opts.SetUseAdaptiveMutex(true)
require.EqualValues(t, true, opts.UseAdaptiveMutex())
opts.SetBytesPerSync(68 << 10)
require.EqualValues(t, 68<<10, opts.GetBytesPerSync())
opts.SetWALBytesPerSync(69 << 10)
require.EqualValues(t, 69<<10, opts.GetWALBytesPerSync())
opts.SetWritableFileMaxBufferSize(9 << 20)
require.EqualValues(t, 9<<20, opts.GetWritableFileMaxBufferSize())
opts.SetAllowConcurrentMemtableWrites(true)
require.EqualValues(t, true, opts.AllowConcurrentMemtableWrites())
opts.SetEnableWriteThreadAdaptiveYield(true)
require.EqualValues(t, true, opts.EnabledWriteThreadAdaptiveYield())
opts.SetMaxSequentialSkipInIterations(199)
require.EqualValues(t, 199, opts.GetMaxSequentialSkipInIterations())
opts.SetDisableAutoCompactions(true)
require.EqualValues(t, true, opts.DisabledAutoCompactions())
opts.SetOptimizeFiltersForHits(true)
require.EqualValues(t, true, opts.OptimizeFiltersForHits())
opts.SetDeleteObsoleteFilesPeriodMicros(1234)
require.EqualValues(t, 1234, opts.GetDeleteObsoleteFilesPeriodMicros())
opts.SetMemTablePrefixBloomSizeRatio(0.3)
require.EqualValues(t, 0.3, opts.GetMemTablePrefixBloomSizeRatio())
opts.SetMaxCompactionBytes(111222)
require.EqualValues(t, 111222, opts.GetMaxCompactionBytes())
opts.SetMemtableHugePageSize(223344)
require.EqualValues(t, 223344, opts.GetMemtableHugePageSize())
opts.SetMaxSuccessiveMerges(99)
require.EqualValues(t, 99, opts.GetMaxSuccessiveMerges())
opts.SetBloomLocality(5)
require.EqualValues(t, 5, opts.GetBloomLocality())
require.EqualValues(t, false, opts.InplaceUpdateSupport())
opts.SetInplaceUpdateSupport(true)
require.EqualValues(t, true, opts.InplaceUpdateSupport())
require.EqualValues(t, 10000, opts.GetInplaceUpdateNumLocks())
opts.SetInplaceUpdateNumLocks(8)
require.EqualValues(t, 8, opts.GetInplaceUpdateNumLocks())
opts.SetReportBackgroundIOStats(true)
require.EqualValues(t, true, opts.ReportBackgroundIOStats())
require.EqualValues(t, 0.0, opts.GetMempurgeThreshold())
opts.SetMempurgeThreshold(0.1)
require.EqualValues(t, 0.1, opts.GetMempurgeThreshold())
opts.SetMaxTotalWalSize(10 << 30)
require.EqualValues(t, 10<<30, opts.GetMaxTotalWalSize())
opts.SetBottommostCompression(ZLibCompression)
require.EqualValues(t, ZLibCompression, opts.GetBottommostCompression())
require.EqualValues(t, SnappyCompression, opts.GetCompression())
opts.SetCompression(LZ4Compression)
require.EqualValues(t, LZ4Compression, opts.GetCompression())
require.EqualValues(t, LevelCompactionStyle, opts.GetCompactionStyle())
opts.SetCompactionStyle(UniversalCompactionStyle)
require.EqualValues(t, UniversalCompactionStyle, opts.GetCompactionStyle())
require.EqualValues(t, false, opts.IsAtomicFlush())
opts.SetAtomicFlush(true)
require.EqualValues(t, true, opts.IsAtomicFlush())
require.EqualValues(t, false, opts.CreateIfMissing())
opts.SetCreateIfMissing(true)
require.EqualValues(t, true, opts.CreateIfMissing())
require.EqualValues(t, false, opts.CreateIfMissingColumnFamilies())
opts.SetCreateIfMissingColumnFamilies(true)
require.EqualValues(t, true, opts.CreateIfMissingColumnFamilies())
opts.SetErrorIfExists(true)
require.EqualValues(t, true, opts.ErrorIfExists())
opts.SetParanoidChecks(true)
require.EqualValues(t, true, opts.ParanoidChecks())
require.EqualValues(t, InfoInfoLogLevel, opts.GetInfoLogLevel())
opts.SetInfoLogLevel(WarnInfoLogLevel)
require.EqualValues(t, WarnInfoLogLevel, opts.GetInfoLogLevel())
require.EqualValues(t, 64<<20, opts.GetWriteBufferSize())
opts.SetWriteBufferSize(1 << 19)
require.EqualValues(t, 1<<19, opts.GetWriteBufferSize())
require.EqualValues(t, 2, opts.GetMaxWriteBufferNumber())
opts.SetMaxWriteBufferNumber(15)
require.EqualValues(t, 15, opts.GetMaxWriteBufferNumber())
require.EqualValues(t, 1, opts.GetMinWriteBufferNumberToMerge())
opts.SetMinWriteBufferNumberToMerge(2)
require.EqualValues(t, 2, opts.GetMinWriteBufferNumberToMerge())
require.EqualValues(t, -1, opts.GetMaxOpenFiles())
opts.SetMaxOpenFiles(999)
require.EqualValues(t, 999, opts.GetMaxOpenFiles())
require.EqualValues(t, 16, opts.GetMaxFileOpeningThreads())
opts.SetMaxFileOpeningThreads(21)
require.EqualValues(t, 21, opts.GetMaxFileOpeningThreads())
opts.SetCompressionPerLevel([]CompressionType{ZLibCompression, SnappyCompression})
opts.SetEnv(NewMemEnv())
opts.SetEnv(NewDefaultEnv())
opts.IncreaseParallelism(8)
opts.OptimizeForPointLookup(19 << 20)
opts.OptimizeLevelStyleCompaction(10 << 20)
opts.OptimizeUniversalStyleCompaction(20 << 20)
require.EqualValues(t, true, opts.AllowConcurrentMemtableWrites())
opts.SetAllowConcurrentMemtableWrites(false)
require.EqualValues(t, false, opts.AllowConcurrentMemtableWrites())
opts.SetCompressionOptionsZstdMaxTrainBytes(123 << 20)
require.EqualValues(t, 123<<20, opts.GetCompressionOptionsZstdMaxTrainBytes())
require.EqualValues(t, 1, opts.GetCompressionOptionsParallelThreads())
opts.SetCompressionOptionsParallelThreads(12)
require.EqualValues(t, 12, opts.GetCompressionOptionsParallelThreads())
opts.AddCompactOnDeletionCollectorFactory(12, 13)
opts.AddCompactOnDeletionCollectorFactoryWithRatio(12, 13, 5.5)
require.EqualValues(t, 0, opts.GetCompressionOptionsMaxDictBufferBytes())
opts.SetCompressionOptionsMaxDictBufferBytes(213 << 10)
require.EqualValues(t, 213<<10, opts.GetCompressionOptionsMaxDictBufferBytes())
opts.SetBottommostCompressionOptionsZstdMaxTrainBytes(234<<20, true)
opts.SetBottommostCompressionOptionsMaxDictBufferBytes(312<<10, true)
opts.SetBottommostCompressionOptions(NewDefaultCompressionOptions(), true)
opts.SetCompressionOptions(NewDefaultCompressionOptions())
opts.SetMinLevelToCompress(2)
require.EqualValues(t, 7, opts.GetNumLevels())
opts.SetNumLevels(8)
require.EqualValues(t, 8, opts.GetNumLevels())
require.EqualValues(t, 2, opts.GetLevel0FileNumCompactionTrigger())
opts.SetLevel0FileNumCompactionTrigger(14)
require.EqualValues(t, 14, opts.GetLevel0FileNumCompactionTrigger())
require.EqualValues(t, 20, opts.GetLevel0SlowdownWritesTrigger())
opts.SetLevel0SlowdownWritesTrigger(17)
require.EqualValues(t, 17, opts.GetLevel0SlowdownWritesTrigger())
require.EqualValues(t, 36, opts.GetLevel0StopWritesTrigger())
opts.SetLevel0StopWritesTrigger(47)
require.EqualValues(t, 47, opts.GetLevel0StopWritesTrigger())
require.EqualValues(t, uint64(0x140000), opts.GetTargetFileSizeBase())
opts.SetTargetFileSizeBase(41 << 20)
require.EqualValues(t, 41<<20, opts.GetTargetFileSizeBase())
require.EqualValues(t, 1, opts.GetTargetFileSizeMultiplier())
opts.SetTargetFileSizeMultiplier(3)
require.EqualValues(t, 3, opts.GetTargetFileSizeMultiplier())
require.EqualValues(t, 10<<20, opts.GetMaxBytesForLevelBase())
opts.SetMaxBytesForLevelBase(1 << 30)
require.EqualValues(t, 1<<30, opts.GetMaxBytesForLevelBase())
require.EqualValues(t, 10, opts.GetMaxBytesForLevelMultiplier())
opts.SetMaxBytesForLevelMultiplier(12)
require.EqualValues(t, 12, opts.GetMaxBytesForLevelMultiplier())
require.EqualValues(t, 1, opts.GetMaxSubcompactions())
opts.SetMaxSubcompactions(3)
require.EqualValues(t, 3, opts.GetMaxSubcompactions())
require.True(t, opts.IsDBIDWrittenToManifest())
opts.WriteDBIDToManifest(false)
require.False(t, opts.IsDBIDWrittenToManifest())
require.False(t, opts.TrackAndVerifyWALsInManifestFlag())
opts.ToggleTrackAndVerifyWALsInManifestFlag(true)
require.True(t, opts.TrackAndVerifyWALsInManifestFlag())
opts.SetMaxBytesForLevelMultiplierAdditional([]int{2 << 20})
opts.SetDbLogDir("./abc")
opts.SetWalDir("../asdf")
require.EqualValues(t, false, opts.EnabledPipelinedWrite())
opts.SetEnablePipelinedWrite(true)
require.EqualValues(t, true, opts.EnabledPipelinedWrite())
require.EqualValues(t, false, opts.UnorderedWrite())
opts.SetUnorderedWrite(true)
require.EqualValues(t, true, opts.UnorderedWrite())
opts.EnableStatistics()
opts.PrepareForBulkLoad()
opts.SetMemtableVectorRep()
opts.SetHashLinkListRep(12)
opts.SetHashSkipListRep(1, 2, 3)
opts.SetPlainTableFactory(1, 2, 3.1, 12, 58922, EncodingTypePlain, true, true)
opts.SetUint64AddMergeOperator()
opts.SetDumpMallocStats(true)
opts.SetMemtableWholeKeyFiltering(true)
require.EqualValues(t, false, opts.AllowIngestBehind())
opts.SetAllowIngestBehind(true)
require.EqualValues(t, true, opts.AllowIngestBehind())
require.EqualValues(t, false, opts.SkipStatsUpdateOnDBOpen())
opts.SetSkipStatsUpdateOnDBOpen(true)
require.EqualValues(t, true, opts.SkipStatsUpdateOnDBOpen())
require.EqualValues(t, false, opts.SkipCheckingSSTFileSizesOnDBOpen())
opts.SetSkipCheckingSSTFileSizesOnDBOpen(true)
require.EqualValues(t, true, opts.SkipCheckingSSTFileSizesOnDBOpen())
opts.CompactionReadaheadSize(88 << 20)
require.EqualValues(t, 88<<20, opts.GetCompactionReadaheadSize())
opts.SetMaxWriteBufferSizeToMaintain(99 << 19)
require.EqualValues(t, 99<<19, opts.GetMaxWriteBufferSizeToMaintain())
// set compaction filter
opts.SetCompactionFilter(NewNativeCompactionFilter(nil))
// set merge operator
opts.SetMergeOperator(NewNativeMergeOperator(nil))
// get option from string
_, err := GetOptionsFromString(nil, "abc")
require.Error(t, err)
opts.SetMaxWriteBufferNumberToMaintain(45)
require.EqualValues(t, 45, opts.GetMaxWriteBufferNumberToMaintain())
require.False(t, opts.IsManualWALFlush())
opts.SetManualWALFlush(true)
require.True(t, opts.IsManualWALFlush())
require.EqualValues(t, 0, opts.GetBlobCompactionReadaheadSize())
opts.SetBlobCompactionReadaheadSize(123)
require.EqualValues(t, 123, opts.GetBlobCompactionReadaheadSize())
require.EqualValues(t, NoCompression, opts.GetWALCompression())
opts.SetWALCompression(LZ4Compression)
require.EqualValues(t, LZ4Compression, opts.GetWALCompression())
require.True(t, opts.GetCompressionOptionsZstdDictTrainer())
opts.SetCompressionOptionsZstdDictTrainer(false)
require.False(t, opts.GetCompressionOptionsZstdDictTrainer())
// require.True(t, opts.GetBottommostCompressionOptionsZstdDictTrainer())
// opts.SetCompressionOptionsZstdDictTrainer(false)
// require.False(t, opts.GetBottommostCompressionOptionsZstdDictTrainer())
require.Equal(t, 0, opts.GetBlobFileStartingLevel())
opts.SetBlobFileStartingLevel(1)
require.Equal(t, 1, opts.GetBlobFileStartingLevel())
require.Equal(t, PrepopulateBlobDisable, opts.GetPrepopulateBlobCache())
opts.SetPrepopulateBlobCache(PrepopulateBlobFlushOnly)
require.Equal(t, PrepopulateBlobFlushOnly, opts.GetPrepopulateBlobCache())
require.False(t, opts.GetAvoidUnnecessaryBlockingIOFlag())
opts.AvoidUnnecessaryBlockingIO(true)
require.True(t, opts.GetAvoidUnnecessaryBlockingIOFlag())
require.Equal(t, StatisticsLevelExceptDetailedTimers, opts.GetStatisticsLevel())
opts.SetStatisticsLevel(StatisticsLevelExceptHistogramOrTimers)
require.Equal(t, StatisticsLevelExceptHistogramOrTimers, opts.GetStatisticsLevel())
require.EqualValues(t, KMinOverlappingRatioCompactionPri, opts.GetCompactionPri())
opts.SetCompactionPri(KRoundRobinCompactionPri)
require.EqualValues(t, KRoundRobinCompactionPri, opts.GetCompactionPri())
require.EqualValues(t, 0, opts.GetTickerCount(TickerType_BACKUP_WRITE_BYTES))
hData := opts.GetHistogramData(HistogramType_BLOB_DB_MULTIGET_MICROS)
require.EqualValues(t, 0, hData.P99)
require.EqualValues(t, uint64(0xfffffffffffffffe), opts.GetPeriodicCompactionSeconds())
opts.SetPeriodicCompactionSeconds(123)
require.EqualValues(t, 123, opts.GetPeriodicCompactionSeconds())
require.EqualValues(t, uint64(0xfffffffffffffffe), opts.GetTTL())
opts.SetTTL(123)
require.EqualValues(t, uint64(123), opts.GetTTL())
require.True(t, opts.IsIdentityFileWritten())
opts.WriteIdentityFile(false)
require.False(t, opts.IsIdentityFileWritten())
opts.SetWriteBufferManager(wbm)
lg := NewStderrLogger(InfoInfoLogLevel, "prefix")
opts.SetInfoLog(lg)
require.NotNil(t, opts.GetInfoLog())
// cloning
cl := opts.Clone()
require.EqualValues(t, 5, cl.GetTableCacheNumshardbits())
}
func TestOptions2(t *testing.T) {
t.Parallel()
t.Run("SetUniversalCompactionOpts", func(t *testing.T) {
t.Parallel()
opts := NewDefaultOptions()
defer opts.Destroy()
opts.SetUniversalCompactionOptions(NewDefaultUniversalCompactionOptions())
})
t.Run("SetFifoCompactionOpts", func(t *testing.T) {
t.Parallel()
opts := NewDefaultOptions()
defer opts.Destroy()
opts.SetFIFOCompactionOptions(NewDefaultFIFOCompactionOptions())
})
t.Run("StatisticString", func(t *testing.T) {
t.Parallel()
opts := NewDefaultOptions()
defer opts.Destroy()
require.Empty(t, opts.GetStatisticsString())
})
}