From f172c69dee6ad308d372122ad29588a3d3490c29 Mon Sep 17 00:00:00 2001 From: Axel Kittenberger Date: Thu, 16 Feb 2012 00:28:03 +0100 Subject: [PATCH] fixing moved from/into deleted directories --- ChangeLog | 2 + default-direct.lua | 2 +- lsyncd.lua | 16 +++---- tests/churn-direct.lua | 6 +-- tests/exclude.lua | 106 ++++++++++++++++++++--------------------- tests/testlib.lua | 96 ++++++++++++++++++------------------- 6 files changed, 115 insertions(+), 113 deletions(-) diff --git a/ChangeLog b/ChangeLog index b8ca850..68fc410 100644 --- a/ChangeLog +++ b/ChangeLog @@ -10,6 +10,8 @@ fix: in case of HUP-reset imply insist=true, since startup is known to be configured correctly. fix: a series of typos in comments, manpage etc. + fix: moves to and from deleted directories (deleted when Lsyncd gets notified) + were not correctly translated change: complain if any "rsyncOps" is given change: splitted the default configurations in their own files. more cleanly seperated from the Lsyncd runner, and highlights it are just diff --git a/default-direct.lua b/default-direct.lua index 0c9e8aa..2b65b55 100644 --- a/default-direct.lua +++ b/default-direct.lua @@ -34,7 +34,7 @@ default.direct = { spawn( event, '/bin/mkdir', - '-p', +-- '-p', event.targetPath ) else diff --git a/lsyncd.lua b/lsyncd.lua index d22ac1b..93d1822 100644 --- a/lsyncd.lua +++ b/lsyncd.lua @@ -1942,13 +1942,13 @@ local Inotify = (function() local etyped = etype if etyped == 'Move' then if not relative2 then - log('Normal', 'Transformed Move to Create for ', sync.config.name) - etyped = 'Create' + log('Normal', 'Transformed Move to Delete for ', sync.config.name) + etyped = 'Delete' elseif not relative then relative = relative2 relative2 = nil - log('Normal', 'Transformed Move to Delete for ', sync.config.name) - etyped = 'Delete' + log('Normal', 'Transformed Move to Create for ', sync.config.name) + etyped = 'Create' end end sync:delay(etyped, time, relative, relative2) @@ -2042,13 +2042,13 @@ local Fsevents = (function() local etyped = etype if etyped == 'Move' then if not relative2 then - log('Normal', 'Transformed Move to Create for ', sync.config.name) - etyped = 'Create' + log('Normal', 'Transformed Move to Delete for ', sync.config.name) + etyped = 'Delete' elseif not relative then relative = relative2 relative2 = nil - log('Normal', 'Transformed Move to Delete for ', sync.config.name) - etyped = 'Delete' + log('Normal', 'Transformed Move to Create for ', sync.config.name) + etyped = 'Create' end end sync:delay(etyped, time, relative, relative2) diff --git a/tests/churn-direct.lua b/tests/churn-direct.lua index 2ba023e..49aac7f 100755 --- a/tests/churn-direct.lua +++ b/tests/churn-direct.lua @@ -11,13 +11,13 @@ cwriteln('****************************************************************') local tdir, srcdir, trgdir = mktemps() --- makes some startup data +-- makes some startup data churn(srcdir, 10) -local logs = {'-log', 'Exec'} +local logs = {'-log', 'Exec' } local pid = spawn( './lsyncd', - '-nodaemon', + '-nodaemon', '-direct', srcdir, trgdir, unpack(logs) ) diff --git a/tests/exclude.lua b/tests/exclude.lua index 38bd45b..c0e32a3 100755 --- a/tests/exclude.lua +++ b/tests/exclude.lua @@ -1,109 +1,109 @@ #!/usr/bin/lua -require("posix") -dofile("tests/testlib.lua") +require('posix') +dofile('tests/testlib.lua') -cwriteln("****************************************************************") -cwriteln(" Testing excludes ") -cwriteln("****************************************************************") +cwriteln('****************************************************************') +cwriteln(' Testing excludes') +cwriteln('****************************************************************') local tdir, srcdir, trgdir = mktemps() -local logfile = tdir .. "log" -local cfgfile = tdir .. "config.lua" +local logfile = tdir .. 'log' +local cfgfile = tdir .. 'config.lua' local range = 5 -local log = {"-log", "all"} +local log = {'-log', 'all'} writefile(cfgfile, [[ settings = { - logfile = "]]..logfile..[[", + logfile = ']]..logfile..[[', nodaemon = true, delay = 3, } sync { default.rsync, - source = "]]..srcdir..[[", - target = "]]..trgdir..[[", + source = ']]..srcdir..[[', + target = ']]..trgdir..[[', exclude = { - "erf", - "/eaf", - "erd/", - "/ead", + 'erf', + '/eaf', + 'erd/', + '/ead', }, }]]); -- writes all files -local function writefiles() - posix.mkdir(srcdir .. "d"); - writefile(srcdir .. "erf", "erf"); - writefile(srcdir .. "eaf", "erf"); - writefile(srcdir .. "erd", "erd"); - writefile(srcdir .. "ead", "ead"); - writefile(srcdir .. "d/erf", "erf"); - writefile(srcdir .. "d/eaf", "erf"); - writefile(srcdir .. "d/erd", "erd"); - writefile(srcdir .. "d/ead", "ead"); +local function writefiles() + posix.mkdir(srcdir .. 'd'); + writefile(srcdir .. 'erf', 'erf'); + writefile(srcdir .. 'eaf', 'erf'); + writefile(srcdir .. 'erd', 'erd'); + writefile(srcdir .. 'ead', 'ead'); + writefile(srcdir .. 'd/erf', 'erf'); + writefile(srcdir .. 'd/eaf', 'erf'); + writefile(srcdir .. 'd/erd', 'erd'); + writefile(srcdir .. 'd/ead', 'ead'); end -- test if the filename exists, fails if this is different to expect -local function testfile(filename, expect) +local function testfile(filename, expect) local stat, err = posix.stat(filename) if stat and not expect then - cwriteln("failure: ",filename," should be excluded"); + cwriteln('failure: ',filename,' should be excluded'); os.exit(1); end if not stat and expect then - cwriteln("failure: ",filename," should not be excluded"); + cwriteln('failure: ',filename,' should not be excluded'); os.exit(1); end end -- test all files -local function testfiles() - testfile(srcdir .. "erf", false); - testfile(srcdir .. "eaf", false); - testfile(srcdir .. "erd", true); - testfile(srcdir .. "ead", true); - testfile(srcdir .. "d/erf", false); - testfile(srcdir .. "d/eaf", true); - testfile(srcdir .. "d/erd", true); - testfile(srcdir .. "d/ead", true); +local function testfiles() + testfile(srcdir .. 'erf', false); + testfile(srcdir .. 'eaf', false); + testfile(srcdir .. 'erd', true); + testfile(srcdir .. 'ead', true); + testfile(srcdir .. 'd/erf', false); + testfile(srcdir .. 'd/eaf', true); + testfile(srcdir .. 'd/erd', true); + testfile(srcdir .. 'd/ead', true); end -cwriteln("testing startup excludes"); +cwriteln('testing startup excludes'); writefiles(); -cwriteln("starting Lsyncd"); -local pid = spawn("./lsyncd", cfgfile); -cwriteln("waiting for Lsyncd to start"); +cwriteln('starting Lsyncd'); +local pid = spawn('./lsyncd', cfgfile); +cwriteln('waiting for Lsyncd to start'); posix.sleep(3) -cwriteln("testing excludes after startup"); +cwriteln('testing excludes after startup'); testfiles(); -cwriteln("ok, removing sources"); -if srcdir:sub(1,4) ~= "/tmp" then +cwriteln('ok, removing sources'); +if srcdir:sub(1,4) ~= '/tmp' then -- just to make sure before rm -rf - cwriteln("exist before drama, srcdir is '", srcdir, "'"); + cwriteln('exist before drama, srcdir is '', srcdir, '''); os.exit(1); end -os.execute("rm -rf "..srcdir.."/*"); -writeln("waiting for Lsyncd to remove destination"); -if os.execute("diff -urN "..srcdir.." "..trgdir) ~= 0 then +os.execute('rm -rf '..srcdir..'/*'); +writeln('waiting for Lsyncd to remove destination'); +if os.execute('diff -urN '..srcdir..' '..trgdir) ~= 0 then os.exit(1); end posix.sleep(5); -writeln("writing files after startup"); +writeln('writing files after startup'); writefiles(); -writeln("waiting for Lsyncd to transmit changes"); +writeln('waiting for Lsyncd to transmit changes'); posix.sleep(5); testfiles(); -writeln("killing started Lsyncd"); +writeln('killing started Lsyncd'); posix.kill(pid); local _, exitmsg, lexitcode = posix.wait(lpid); -cwriteln("Exitcode of Lsyncd = ", exitmsg, " ", lexitcode); +cwriteln('Exitcode of Lsyncd = ', exitmsg, ' ', lexitcode); posix.sleep(1); if lexitcode == 0 then - cwriteln("OK"); + cwriteln('OK'); end os.exit(lexitcode); diff --git a/tests/testlib.lua b/tests/testlib.lua index b5e37c6..bca52dc 100644 --- a/tests/testlib.lua +++ b/tests/testlib.lua @@ -1,28 +1,28 @@ -- common testing environment -require("posix") +require('posix') -- escape codes to colorize output on terminal -local c1="\027[47;34m" -local c0="\027[0m" +local c1='\027[47;34m' +local c0='\027[0m' --- -- writes colorized -- function cwriteln(...) io.write(c1, ...) - io.write(c0, "\n") + 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) +-- if environemnt 'SEED' is set, use that as 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() @@ -30,24 +30,24 @@ function mktempd() local s = f:read('*a') f:close() s = s:gsub('[\n\r]+', ' ') - s = s:match("^%s*(.-)%s*$") + s = s:match('^%s*(.-)%s*$') return s end ----- -- creates a tmp directory with the -- typical lsyncd test architecture --- +-- -- @returns path of tmpdir -- path of srcdir -- path of trgdir -- function mktemps() - local tdir = mktempd().."/" - cwriteln("using ", tdir, " as test root") - local srcdir = tdir.."src/" - local trgdir = tdir.."trg/" + local tdir = mktempd()..'/' + cwriteln('using ', tdir, ' as test root') + local srcdir = tdir..'src/' + local trgdir = tdir..'trg/' posix.mkdir(srcdir) posix.mkdir(trgdir) return tdir, srcdir, trgdir @@ -58,9 +58,9 @@ end -- and adds a newline. -- function writefile(filename, text) - local f = io.open(filename, "w") + local f = io.open(filename, 'w') if not f then - cwriteln("Cannot open '"..filename.."' for writing.") + cwriteln('Cannot open "'..filename..'" for writing.') return false end f:write(text) @@ -76,16 +76,16 @@ end -- function spawn(...) args = {...} - cwriteln("spawning: ", table.concat(args, " ")) + cwriteln('spawning: ', table.concat(args, ' ')) local pid = posix.fork() if pid < 0 then - cwriteln("Error, failed fork!") + cwriteln('Error, failed fork!') os.exit(-1) end if pid == 0 then posix.exec(...) -- should not return - cwriteln("Error, failed to spawn: ", ...) + cwriteln('Error, failed to spawn: ', ...) os.exit(-1); end return pid @@ -97,9 +97,9 @@ end -- @param rootdir ... the directory to make data in -- @param n ... roughly how much data action will done -- -function churn(rootdir, n) +function churn(rootdir, n) -- all dirs created, indexed by integer and path - root = {name=""} + root = {name=''} alldirs = {root} dirsWithFileI = {} dirsWithFileD = {} @@ -110,11 +110,11 @@ function churn(rootdir, n) -- name is internal recursive paramter, keep it nil. -- local function dirname(dir, name) - name = name or "" + name = name or '' if not dir then return name end - return dirname(dir.parent, dir.name .. "/" .. name) + return dirname(dir.parent, dir.name .. '/' .. name) end ----- @@ -133,7 +133,7 @@ function churn(rootdir, n) ---- -- Picks a random file. -- - -- Returns 3 values: + -- Returns 3 values: -- * the directory -- * the filename -- * number of files in directory @@ -158,7 +158,7 @@ function churn(rootdir, n) -- picks one file at random local cr = math.random(1, c) - local fn + local fn for name, _ in pairs(rdir) do if #name == 2 then -- filenames are 2 chars wide. @@ -184,7 +184,7 @@ function churn(rootdir, n) 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 + if v == dir then table.remove(dirsWithFileI, i) break end @@ -194,16 +194,16 @@ function churn(rootdir, n) end ---- - -- possible randomized behaviour. + -- possible randomized behaviour. -- just gives it a pause -- local function sleep() - cwriteln("..zzz..") + cwriteln('..zzz..') posix.sleep(1) end ---- - -- possible randomized behaviour. + -- possible randomized behaviour. -- creates a directory -- local function mkdir() @@ -214,19 +214,19 @@ function churn(rootdir, n) if not rdir[nn] then local ndir = { name = nn, - parent = rdir, + parent = rdir, } local dn = dirname(ndir) rdir[nn] = dn table.insert(alldirs, ndir) - cwriteln("mkdir "..rootdir..dn) + cwriteln('mkdir '..rootdir..dn) posix.mkdir(rootdir..dn) end end ---- - -- possible randomized behaviour. - -- creates a directory + -- possible randomized behaviour. + -- Creates a file. -- local function mkfile() -- chooses a random directory to create it into @@ -234,8 +234,8 @@ function churn(rootdir, n) -- 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 f = io.open(rootdir..fn, "w") + 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))) @@ -251,14 +251,14 @@ function churn(rootdir, n) end ---- - -- possible randomized behaviour. - -- moves a directory + -- possible randomized behaviour, + -- moves a directory. -- local function mvdir() if #alldirs <= 2 then return end - -- chooses a random directory to move + -- chooses a random directory to move local odir = pickDir(true) -- chooses a random directory to move to local tdir = pickDir() @@ -277,7 +277,7 @@ function churn(rootdir, n) end local on = dirname(odir) local tn = dirname(tdir) - cwriteln("mvdir ",rootdir,on," -> ",rootdir,tn,odir.name) + cwriteln('mvdir ',rootdir,on,' -> ',rootdir,tn,odir.name) os.rename(rootdir..on, rootdir..tn..odir.name) odir.parent[odir.name] = nil odir.parent = tdir @@ -285,8 +285,8 @@ function churn(rootdir, n) end ---- - -- possible randomized behaviour. - -- moves a directory + -- possible randomized behaviour, + -- moves a file. -- local function mvfile() local odir, fn, c = pickFile() @@ -298,7 +298,7 @@ function churn(rootdir, n) local tdir = pickDir() local on = dirname(odir) local tn = dirname(tdir) - cwriteln("mvfile ",rootdir,on,fn," -> ",rootdir,tn,fn) + cwriteln('mvfile ',rootdir,on,fn,' -> ',rootdir,tn,fn) os.rename(rootdir..on..fn, rootdir..tn..fn) rmFileReference(odir, fn, c) @@ -310,14 +310,14 @@ function churn(rootdir, n) end ---- - -- possible randomized behaviour. - -- moves a directory. + -- 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) + cwriteln('rmfile ',rootdir,dn,fn) posix.unlink(rootdir..dn..fn) rmFileReference(dir, fn, c) end @@ -331,7 +331,7 @@ 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] @@ -339,7 +339,7 @@ function churn(rootdir, n) end for ai=1,n do - -- throw a die what to do + -- throws a die what to do local acn = math.random(ndice) for i, d in ipairs(dice) do if acn <= d[1] then