File: net.box_readahead_gh-3958.test.lua

package info (click to toggle)
tarantool 2.6.0-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 85,364 kB
  • sloc: ansic: 513,760; cpp: 69,489; sh: 25,650; python: 19,190; perl: 14,973; makefile: 4,173; yacc: 1,329; sql: 1,074; pascal: 620; ruby: 190; awk: 18; lisp: 7
file content (30 lines) | stat: -rw-r--r-- 854 bytes parent folder | download | duplicates (3)
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
test_run = require('test_run').new()
test_run:cmd('restart server default')
net = require('net.box')

--
-- gh-3958 updating box.cfg.readahead doesn't affect existing connections.
--
readahead = box.cfg.readahead

box.cfg{readahead = 128}

s = box.schema.space.create("test")
_ = s:create_index("pk")
box.schema.user.grant("guest", "read,write", "space", "test")

-- connection is created with small readahead value,
-- make sure it is updated if box.cfg.readahead is changed.
c = net.connect(box.cfg.listen)

box.cfg{readahead = 100 * 1024}

box.error.injection.set("ERRINJ_WAL_DELAY", true)
pad = string.rep('x', 8192)
for i = 1, 5 do c.space.test:replace({i, pad}, {is_async = true}) end
box.error.injection.set("ERRINJ_WAL_DELAY", false)

test_run:wait_log('default', 'readahead limit is reached', 1024, 0.1)

s:drop()
box.cfg{readahead = readahead}