code cleanups

This commit is contained in:
Axel Kittenberger 2016-12-06 13:19:35 +01:00
parent 815d2c4779
commit 4c77666281
2 changed files with 295 additions and 167 deletions

View File

@ -494,9 +494,9 @@ local Combiner = ( function( )
log(
'Delay',
d2.etype, ':',d2.path,
d2.etype, ': ',d2.path,
' absorbed by ',
d1.etype,':',d1.path
d1.etype,': ',d1.path
)
return 'absorb'
@ -509,24 +509,23 @@ local Combiner = ( function( )
local function refi( d1, d2 )
-- but a directory blocks
if d2.path:byte( -1 ) == 47 then
if d2.path:byte( -1 ) == 47
then
log(
'Delay',
d2.etype,':',d2.path,
d2.etype,': ',d2.path,
' blocked by ',
d1.etype,':',d1.path
d1.etype,': ',d1.path
)
return 'stack'
end
log(
'Delay',
d2.etype, ':', d2.path,
d2.etype, ': ', d2.path,
' replaces ',
d1.etype, ':', d1.path
d1.etype, ': ', d1.path
)
return 'replace'
@ -540,9 +539,9 @@ local Combiner = ( function( )
log(
'Delay',
d2.etype, ':', d2.path,
d2.etype, ': ', d2.path,
' replaces ',
d1.etype, ':', d1.path
d1.etype, ': ', d1.path
)
return 'replace'
@ -556,9 +555,9 @@ local Combiner = ( function( )
log(
'Delay',
d2.etype,':',d2.path,
d2.etype,': ',d2.path,
' nullifies ',
d1.etype,':',d1.path
d1.etype,': ',d1.path
)
return 'remove'

View File

@ -1,40 +1,48 @@
-- common testing environment
posix = require('posix')
posix = require( 'posix' )
-- escape codes to colorize output on terminal
local c1='\027[47;34m'
local c0='\027[0m'
---
--
-- writes colorized
--
function cwriteln(...)
io.write(c1, ...)
io.write(c0, '\n')
io.write( c1, '++ ', ... )
io.write( c0, '\n' )
end
-----
--
-- initializes the pseudo random generator
-- if environemnt 'SEED' is set, use that as seed.
local seed = os.getenv('SEED') or os.time()
math.randomseed(seed)
cwriteln('random seed: ', seed)
local seed = os.getenv( 'SEED') or os.time( )
-----
math.randomseed( seed )
cwriteln( 'random seed: ', seed )
--
-- creates a tmp directory
--
-- @returns the name of the directory
--
function mktempd()
local f = io.popen('mktemp -td ltest.XXX', 'r')
local s = f:read('*a')
f:close()
s = s:gsub('[\n\r]+', ' ')
s = s:match('^%s*(.-)%s*$')
function mktempd( )
local f = io.popen( 'mktemp -td ltest.XXX', 'r' )
local s = f:read( '*a' )
f:close( )
s = s:gsub( '[\n\r]+', ' ' )
s = s:match( '^%s*(.-)%s*$' )
return s
end
-----
--
-- creates a tmp directory with the
-- typical lsyncd test architecture
--
@ -43,94 +51,129 @@ end
-- path of trgdir
--
function mktemps()
local tdir = mktempd()..'/'
cwriteln('using ', tdir, ' as test root')
function mktemps( )
local tdir = mktempd() .. '/'
cwriteln( 'using ', tdir, ' as test root' )
local srcdir = tdir..'src/'
local trgdir = tdir..'trg/'
posix.mkdir(srcdir)
posix.mkdir(trgdir)
posix.mkdir( srcdir )
posix.mkdir( trgdir )
return tdir, srcdir, trgdir
end
----
-- Writes a file with 'text' in it.
--
-- Writes a file with 'text' in it
-- and adds a newline.
--
function writefile(filename, text)
local f = io.open(filename, 'w')
if not f then
cwriteln('Cannot open "'..filename..'" for writing.')
function writefile( filename, text )
local f = io.open( filename, 'w' )
if not f
then
cwriteln( 'Cannot open "'..filename..'" for writing.' )
return false
end
f:write(text)
f:write('\n')
f:close()
f:write( text )
f:write( '\n' )
f:close( )
return true
end
-----
--
-- spawns a subprocess.
--
-- @returns the processes pid
--
function spawn(...)
args = {...}
cwriteln('spawning: ', table.concat(args, ' '))
local pid = posix.fork()
if pid < 0 then
cwriteln('Error, failed fork!')
os.exit(-1)
args = { ... }
cwriteln( 'spawning: ', table.concat( args, ' ' ) )
local pid = posix.fork( )
if pid < 0
then
cwriteln( 'Error, failed fork!' )
os.exit( -1 )
end
if pid == 0 then
posix.exec(...)
if pid == 0
then
posix.exec( ... )
-- should not return
cwriteln('Error, failed to spawn: ', ...)
os.exit(-1);
cwriteln( 'Error, failed to spawn: ', ... )
os.exit( -1 )
end
return pid
end
-----
--
-- Makes a lot of random data
--
-- @param rootdir ... the directory to make data in
-- @param n ... roughly how much data action will done
--
function churn(rootdir, n)
-- all dirs created, indexed by integer and path
root = {name=''}
alldirs = {root}
dirsWithFileI = {}
dirsWithFileD = {}
function churn( rootdir, n )
-----
-- all dirs created, indexed by integer and path
root = { name = '' }
alldirs = { root }
dirsWithFileI = { }
dirsWithFileD = { }
--
-- returns the name of a directory
--
-- name is internal recursive paramter, keep it nil.
--
local function dirname(dir, name)
local function dirname( dir, name )
name = name or ''
if not dir then
if not dir
then
return name
end
return dirname(dir.parent, dir.name .. '/' .. name)
return dirname( dir.parent, dir.name .. '/' .. name )
end
-----
--
-- Picks a random dir.
--
local function pickDir(notRoot)
if notRoot then
if #alldirs <= 2 then
local function pickDir( notRoot )
if notRoot
then
if #alldirs <= 2
then
return nil
end
return alldirs[math.random(2, #alldirs)]
return alldirs[ math.random( 2, #alldirs ) ]
end
return alldirs[math.random(#alldirs)]
return alldirs[ math.random( #alldirs ) ]
end
----
--
-- Picks a random file.
--
-- Returns 3 values:
@ -138,188 +181,266 @@ function churn(rootdir, n)
-- * the filename
-- * number of files in directory
--
local function pickFile()
local function pickFile( )
-- picks the random directory
if #dirsWithFileI < 1 then
if #dirsWithFileI < 1
then
return
end
local rdir = dirsWithFileI[math.random(1, #dirsWithFileI)]
if not rdir then
local rdir = dirsWithFileI[ math.random( 1, #dirsWithFileI ) ]
if not rdir
then
return
end
-- counts the files in there
local c = 0
for name, _ in pairs(rdir) do
if #name == 2 then
for name, _ in pairs(rdir)
do
if #name == 2
then
c = c + 1
end
end
-- picks one file at random
local cr = math.random(1, c)
local cr = math.random( 1, c )
local fn
for name, _ in pairs(rdir) do
if #name == 2 then
for name, _ in pairs( rdir )
do
if #name == 2
then
-- filenames are 2 chars wide.
cr = cr - 1
if cr == 0 then
if cr == 0
then
fn = name
break
end
end
end
return rdir, fn, c
end
-----
--
-- Removes a reference to a file
--
-- @param dir --- directory reference
-- @param fn --- filename
-- @param c --- number of files in dir
-- @param dir -- directory reference
-- @param fn -- filename
-- @param c -- number of files in dir
--
local function rmFileReference(dir, fn, c)
local function rmFileReference( dir, fn, c )
dir[fn] = nil
if c == 1 then
if c == 1
then
-- if last file from origin dir, it has no files anymore
for i, v in ipairs(dirsWithFileI) do
if v == dir then
table.remove(dirsWithFileI, i)
for i, v in ipairs( dirsWithFileI )
do
if v == dir
then
table.remove( dirsWithFileI, i )
break
end
end
dirsWithFileD[dir] = nil
dirsWithFileD[ dir ] = nil
end
end
----
--
-- possible randomized behaviour.
-- just gives it a pause
--
local function sleep()
cwriteln('..zzz..')
posix.sleep(1)
local function sleep( )
cwriteln( '..zzz..' )
posix.sleep( 1 )
end
----
--
-- possible randomized behaviour.
-- creates a directory
--
local function mkdir()
local function mkdir( )
-- chooses a random directory to create it into
local rdir = pickDir()
local rdir = pickDir( )
-- creates a new random one letter name
local nn = string.char(96 + math.random(26))
if not rdir[nn] then
local nn = string.char( 96 + math.random( 26 ) )
if not rdir[nn]
then
local ndir = {
name = nn,
parent = rdir,
}
local dn = dirname(ndir)
rdir[nn] = dn
table.insert(alldirs, ndir)
cwriteln('mkdir '..rootdir..dn)
posix.mkdir(rootdir..dn)
local dn = dirname( ndir )
rdir[ nn ] = dn
table.insert( alldirs, ndir )
cwriteln( 'mkdir '..rootdir..dn )
posix.mkdir( rootdir..dn )
end
end
----
--
-- possible randomized behaviour.
-- Creates a file.
--
local function mkfile()
local function mkfile( )
-- chooses a random directory to create it into
local rdir = pickDir()
-- creates a new random one letter name
local nn = 'f'..string.char(96 + math.random(26))
local fn = dirname(rdir) .. nn
cwriteln('mkfile '..rootdir..fn)
local nn = 'f'..string.char( 96 + math.random( 26 ) )
local fn = dirname( rdir ) .. nn
cwriteln( 'mkfile ' .. rootdir .. fn )
local f = io.open(rootdir..fn, 'w')
if f then
for i=1,10 do
f:write(string.char(96 + math.random(26)))
if f
then
for i = 1, 10
do
f:write( string.char( 96 + math.random( 26 ) ) )
end
f:write('\n')
f:close()
rdir[nn]=true
if not dirsWithFileD[rdir] then
table.insert(dirsWithFileI, rdir)
dirsWithFileD[rdir]=true
f:write( '\n' )
f:close( )
rdir[ nn ]=true
if not dirsWithFileD[ rdir ]
then
table.insert( dirsWithFileI, rdir )
dirsWithFileD[ rdir ]=true
end
end
end
----
-- possible randomized behaviour,
-- moves a directory.
--
local function mvdir()
if #alldirs <= 2 then
-- Possible randomized behaviour:
-- Moves a directory.
--
local function mvdir( )
if #alldirs <= 2
then
return
end
-- chooses a random directory to move
local odir = pickDir(true)
local odir = pickDir( true )
-- chooses a random directory to move to
local tdir = pickDir()
local tdir = pickDir( )
-- makes sure tdir is not a subdir of odir
local dd = tdir
while dd do
if odir == dd then
while dd
do
if odir == dd
then
return
end
dd = dd.parent
end
-- origin name in the target dir already
if tdir[odir.name] ~= nil then
if tdir[odir.name] ~= nil
then
return
end
local on = dirname(odir)
local tn = dirname(tdir)
cwriteln('mvdir ',rootdir,on,' -> ',rootdir,tn,odir.name)
os.rename(rootdir..on, rootdir..tn..odir.name)
odir.parent[odir.name] = nil
local on = dirname( odir )
local tn = dirname( tdir )
cwriteln( 'mvdir ', rootdir,on, ' -> ', rootdir, tn, odir.name )
os.rename( rootdir..on, rootdir..tn..odir.name )
odir.parent[ odir.name ] = nil
odir.parent = tdir
tdir[odir.name] = odir
tdir[ odir.name ] = odir
end
----
--
-- possible randomized behaviour,
-- moves a file.
--
local function mvfile()
local odir, fn, c = pickFile()
if not odir then
local function mvfile( )
local odir, fn, c = pickFile( )
if not odir
then
return
end
-- picks a directory with a file at random
-- picks a target directory at random
local tdir = pickDir()
local on = dirname(odir)
local tn = dirname(tdir)
cwriteln('mvfile ',rootdir,on,fn,' -> ',rootdir,tn,fn)
os.rename(rootdir..on..fn, rootdir..tn..fn)
rmFileReference(odir, fn, c)
local tdir = pickDir( )
tdir[fn] = true
if not dirsWithFileD[tdir] then
dirsWithFileD[tdir] = true
table.insert(dirsWithFileI, tdir)
local on = dirname( odir )
local tn = dirname( tdir )
cwriteln( 'mvfile ', rootdir, on, fn, ' -> ', rootdir, tn, fn )
os.rename( rootdir..on..fn, rootdir..tn..fn )
rmFileReference( odir, fn, c )
tdir[ fn ] = true
if not dirsWithFileD[ tdir ]
then
dirsWithFileD[ tdir ] = true
table.insert( dirsWithFileI, tdir )
end
end
----
--
-- possible randomized behaviour,
-- removes a file.
--
local function rmfile()
local dir, fn, c = pickFile()
if dir then
local dn = dirname(dir)
cwriteln('rmfile ',rootdir,dn,fn)
posix.unlink(rootdir..dn..fn)
rmFileReference(dir, fn, c)
local function rmfile( )
local dir, fn, c = pickFile( )
if dir
then
local dn = dirname( dir )
cwriteln( 'rmfile ', rootdir, dn, fn )
posix.unlink( rootdir..dn..fn )
rmFileReference( dir, fn, c )
end
end
@ -331,19 +452,27 @@ function churn(rootdir, n)
{ 20, rmfile },
}
cwriteln('making random data')
cwriteln( 'making random data' )
local ndice = 0
for i, d in ipairs(dice) do
ndice = ndice + d[1]
d[1] = ndice
for i, d in ipairs( dice )
do
ndice = ndice + d[ 1 ]
d[ 1 ] = ndice
end
for ai=1,n do
for ai = 1, n
do
-- throws a die what to do
local acn = math.random(ndice)
for i, d in ipairs(dice) do
if acn <= d[1] then
d[2]()
local acn = math.random( ndice )
for i, d in ipairs( dice )
do
if acn <= d[ 1 ]
then
d[ 2 ]( )
break
end
end