diff --git a/Script/cs/StorageBackends/eosstorage.py b/Script/cs/StorageBackends/eosstorage.py index 95741309f97f434375339186b08cb7197b8b7747..781358d25ac44190129e8632a2ec0344f0f40a99 100644 --- a/Script/cs/StorageBackends/eosstorage.py +++ b/Script/cs/StorageBackends/eosstorage.py @@ -85,8 +85,6 @@ def remove(dstfile, stager, logger=None): def backgroundcopy(srcfile, dstfile, stager, logger=None): - del logger #unused args - dstfile = 'root://%s/%s' % (stager, dstfile) cmd = ['xrdcp', '-f', '--nopbar', srcfile, dstfile] diff --git a/Script/cs/Threads/CopyThread.py b/Script/cs/Threads/CopyThread.py index 75959ae710243ac1a73a65b5fe4efbaa32969344..4aea7c1672505590e4ddd5926273f38e2adecce8 100644 --- a/Script/cs/Threads/CopyThread.py +++ b/Script/cs/Threads/CopyThread.py @@ -113,7 +113,7 @@ class CopyThread(threading.Thread): fmd = self.copyqueue.get_nowait() # fmd: file meta data except queue.Empty: return - self.logger.debug('got file from queue: %s', fmd.file_name) + self.logger.debug('got file from queue: %s', fmd) # Check if filesystem was locked while the file was in the copyqueue if dir_is_locked(os.path.dirname(fmd.file_name), self.conf.SrcDirs, diff --git a/Script/cs/Threads/ManagerThread.py b/Script/cs/Threads/ManagerThread.py index 82ae44288f2ca3df63ceab77998d1163d07e1809..0d0b9747c738a07ec1f8c68f5a5133b81ed75fa2 100644 --- a/Script/cs/Threads/ManagerThread.py +++ b/Script/cs/Threads/ManagerThread.py @@ -346,13 +346,21 @@ class ManagerThread(threading.Thread): # 'StageHost' is for backward compatibility eosinstance = line.split()[2] - self.logger.debug('filemetadata: remote dir = %s, eos instance = %s', - remotedir, eosinstance) - - if not infofile.endswith(Constants.copied_ext): - os.rename(infofile, filename + Constants.tobecopied_ext) - - return FileMetaData.FileMetaData(filename, remotedir, eosinstance, mtime) + if remotedir == '' or eosinstance == '': + # empty file, invalid data, etc. + self.logger.warning( + 'invalid metadata in %s (remotedir="%s", eosinstance="%s")' + ': deleting infofile and getting metadata from scratch' + , infofile, remotedir, eosinstance) + os.remove(infofile) + else: + self.logger.debug('filemetadata: remote dir = %s, eos instance = %s', + remotedir, eosinstance) + + if not infofile.endswith(Constants.copied_ext): + os.rename(infofile, filename + Constants.tobecopied_ext) + + return FileMetaData.FileMetaData(filename, remotedir, eosinstance, mtime) try: parsed = self.parser(filename)