示例#1
0
    def testStoredFiles(self):
        Environment.cleanupTestFolder()

        targetFolder = Environment.targetFolder()

        # Create some files in target folder
        if not os.path.exists(targetFolder):
            os.makedirs(targetFolder)

        filename = os.path.join(targetFolder, 'myName_20180304_1200.zip')
        filename2 = os.path.join(targetFolder, 'otherName_20180304_1200.zip')

        with open(filename, 'w') as f:
            f.write('Simple test file for BRIT')

        with open(filename2, 'w') as f:
            f.write('Simple test file for BRIT')

        newConfig = Configuration()
        newConfig.definitions.append(
            Definition('Name1', 'dir', Environment.examplesFolder(),
                       './C/temp1'))

        newTask = Task('myName', ['Name1'],
                       targetFolder=Environment.targetFolder())
        newConfig.addTask(newTask)

        fileNames = []

        for fName in newTask.storedFiles():
            fileNames.append(fName)

        self.assert_(len(fileNames) == 1, "Only one file should be found")
        self.assert_(fileNames[0] == filename, "Wrong file found")
示例#2
0
    def createFiles(self, files):
        # Make sure, target folder exists
        if not os.path.exists(Environment.targetFolder()):
            os.makedirs(Environment.targetFolder())

        for file in files:
            with open(file, 'w') as f:
                f.write('Simple test file for BRIT')
示例#3
0
    def test_prepareTargetFolder(self):
        Environment.cleanupTestFolder()
        targetFolder = os.path.join(Environment.targetFolder(), 'sub')
        newTask = Task('myName', ['Name1'], targetFolder=targetFolder)
        newTask._prepareTargetFolder()

        self.assert_(os.path.exists(targetFolder), 'Targtefolder not created')

        Environment.cleanupTestFolder()
示例#4
0
    def testFileInfos_forFile(self):
        Environment.cleanupTestFolder()
        exampleFile = Environment.setupExamplesDir()

        myDef = Definition('Name1', 'file', exampleFile, 'Test/example.txt')

        infos = []
        for info in myDef.fileInfos():
            infos.append(info)

        self.assert_(len(infos) == 1, 'There should be exactly one fileInfo')
        self.assert_(infos[0]['source'] == exampleFile, 'Source not OK')
        self.assert_(infos[0]['target'] == 'Test/example.txt', 'Target not OK')

        Environment.cleanupTestFolder()
示例#5
0
    def test_doArchiveFileFail(self):
        filename = Environment.setupExamplesDir()
        zipTargetFile = 'dir/example'
        config = Configuration()
        config.backupDirectory = Environment.targetFolder()
        definition = Definition('name1', 'file', filename, zipTargetFile)
        config.definitions.append(definition)

        task = Task('myName', ['name1'])
        config.addTask(task)

        task._prepareTargetFolder()
        targetfile = task._getTargetFilename()
        archiveFile = task._prepareArchive(targetfile)

        # Now the actual test
        # I open and lock the example file to provoke an I/O error
        file_ = open(filename, 'a')
        if os.name == 'nt':
            msvcrt.locking(file_.fileno(), msvcrt.LK_LOCK, 0x7fffffff)

        with LogCapture(level=logging.WARNING) as l:
            task._doArchiveFile(archiveFile, filename, zipTargetFile)
            l.check((
                'root', 'WARNING',
                'File could not be read: C:\\ProgramData\\brit_test\\examples\\example.txt Reason: I/O error(13): Permission denied'
            ))

        archiveFile.close()

        # Unlock and close the file
        if os.name == 'nt':
            msvcrt.locking(file_.fileno(), msvcrt.LK_UNLCK, 0x7fffffff)
        file_.close()

        self.assert_(not self.fileIsZipped(zipTargetFile, targetfile),
                     'File placed in zip file even though it was locked')

        Environment.cleanupTestFolder()
示例#6
0
    def testfilesSize(self):
        Environment.cleanupTestFolder()
        exampleFile = Environment.setupExamplesDir()
        someFiles = Environment.extendExamplesDir()
        someFiles.append(exampleFile)

        myDef = Definition('Name1', 'dir', Environment.examplesFolder(),
                           'Test/Dir')
        self.assert_(myDef.filesSize() == 514, 'FilesSize not OK')

        Environment.cleanupTestFolder()
示例#7
0
    def test_doArchiveFile(self):
        filename = Environment.setupExamplesDir()

        zipTargetFile = 'dir/example'
        config = Configuration()
        config.backupDirectory = Environment.targetFolder()
        definition = Definition('name1', 'file', filename, zipTargetFile)
        config.definitions.append(definition)

        task = Task('myName', ['name1'])
        config.addTask(task)

        task._prepareTargetFolder()
        targetfile = task._getTargetFilename()
        archiveFile = task._prepareArchive(targetfile)

        # Now the actual test
        task._doArchiveFile(archiveFile, filename, zipTargetFile)
        archiveFile.close()

        self.assert_(self.fileIsZipped(zipTargetFile, targetfile),
                     'File not placed in zip file')

        Environment.cleanupTestFolder()
示例#8
0
    def testRun(self):
        Environment.cleanupTestFolder()
        Environment.setupExamplesDir()

        newConfig = Configuration()
        newConfig.definitions.append(
            Definition('Name1', 'dir', Environment.examplesFolder(),
                       './C/temp1'))

        newTask = Task('myName', ['Name1'],
                       targetFolder=Environment.targetFolder())
        newConfig.addTask(newTask)

        filename = newTask.run()

        self.assert_(os.path.exists(Environment.targetFolder()),
                     'Target folder not created')
        self.assert_(filename <> None and filename <> '',
                     'No file name returned on run')

        Environment.cleanupTestFolder()
示例#9
0
    def testfileInfos(self):
        Environment.cleanupTestFolder()
        exampleFile = Environment.setupExamplesDir()

        myDef = Definition('Name1', 'dir', Environment.examplesFolder(),
                           'Test/Dir')

        infos = []
        for info in myDef.fileInfos():
            infos.append(info)

        self.assert_(infos <> None, 'No fileInfos created')
        self.assert_(
            infos[0]['source'] == os.path.join(Environment.examplesFolder(),
                                               'example.txt'),
            'Example source file not OK')
        self.assert_(
            infos[0]['target'] == os.path.join('Test/Dir', 'examples',
                                               'example.txt'),
            'Example source file not OK')

        someFiles = Environment.extendExamplesDir()
        someFiles.append(exampleFile)

        infos = []
        for info in myDef.fileInfos():
            infos.append(info)

        self.assert_(len(infos) == len(someFiles), 'Not all files found')

        myDef.includeDirPattern = ['subfolder']

        infos = []
        for info in myDef.fileInfos():
            infos.append(info)
        # Note that I get all files of the base dir, independent if that matches included dirrs!
        self.assert_(len(infos) == 4, 'Nb of files not OK for include dirs')

        Environment.cleanupTestFolder()
示例#10
0
    def testWriteToReadFrom(self):
        newConfig = Configuration()
        newConfig.addTask(Task('TestTest1', ['config1', 'config2']))
        newConfig.addTask(Task('TestTest2', ['config1', 'config2']))
        newConfig.definitions.append(
            Definition('name1', 'dir', 'C:/temp1', './C/temp1'))
        newConfig.definitions.append(
            Definition('name2', 'dir', 'C:/temp2', './C/temp2'))
        newConfig.definitions.append(
            Definition('name3', 'dir', 'C:/temp3', './C/temp3'))
        newConfig.retainStrategies.append(RetainStrategy('reatinDefault'))
        newConfig.backupDirectory = 'c:/temp/backup'

        Environment.cleanupTestFolder()
        Environment.setupExamplesDir()
        testFile = os.path.join(Environment.examplesFolder(),
                                'test_config.brit')

        newConfig.writeTo(testFile)
        self.assert_(os.path.isfile(testFile), 'No config file written')

        newConfig2 = Configuration.readFrom(testFile)

        self.assert_(newConfig2 <> None,
                     'No configuration has been read from Json')
        self.assert_(
            len(newConfig2.tasks) == 2, 'Length of list of tasks not OK')
        self.assert_(newConfig2.tasks[0].name == 'TestTest1',
                     'Name of first task not OK')
        self.assert_(newConfig2.tasks[0].configuration == newConfig2,
                     'Configuration of task not set')

        self.assert_(
            len(newConfig2.definitions) == 3,
            'Length of list of Definitions not OK')
        self.assert_(
            len(newConfig2.retainStrategies) == 1,
            'Length of list of RetainStrategies not OK')

        self.assert_(newConfig2.backupDirectory == 'c:/temp/backup',
                     'backupDirectory not OK')

        Environment.cleanupTestFolder()
示例#11
0
    def testSaveToReadFrom(self):
        newMapping = FileMapping()
        newMapping.addItem(u'c:/temp/x1.txt', u'Temp/x1.txt')
        newMapping.addItem(u'c:/temp/x2.txt', u'Temp/x2.txt')

        Environment.cleanupTestFolder()
        Environment.setupExamplesDir()
        testFile = os.path.join(Environment.examplesFolder(),
                                'test_mapping.json')

        newMapping.saveTo(testFile)

        self.assert_(os.path.isfile(testFile), 'No mapping file written')
        newMapping2 = FileMapping.readFrom(testFile)

        self.assert_(newMapping2 <> None, 'No mapping read')
        self.assert_(
            len(newMapping2.itemMappings) == 2, 'Nb of items mappings not OK')
        self.assert_(
            newMapping2.itemMappings[u'c:/temp/x1.txt'] == u'Temp/x1.txt',
            'Mapping item not added')

        Environment.cleanupTestFolder()
示例#12
0
    def testapplyOnFiles(self):
        Environment.cleanupTestFolder()

        targetFolder = Environment.targetFolder()

        filename1 = os.path.join(targetFolder, 'myName_1.zip')
        filename2 = os.path.join(targetFolder, 'myName_2.zip')
        filename3 = os.path.join(targetFolder, 'myName_3.zip')
        filename4 = os.path.join(targetFolder, 'myName_4.zip')

        files = [filename1, filename2, filename3, filename4]

        time_now = datetime.now()

        # Let's do a test with days
        self.createFiles(files)
        self.setFileTime(filename1, time_now - timedelta(minutes=1))
        self.setFileTime(filename2, time_now - timedelta(days=1))
        self.setFileTime(filename3, time_now - timedelta(days=1, minutes=5))
        self.setFileTime(filename4, time_now - timedelta(days=3))

        RS = RetainStrategy('aStrat', timedelta(days=1), "day")
        RS.applyOnFiles(files)

        self.assert_(os.path.isfile(filename1), "File 1 should not be deleted")
        self.assert_(os.path.isfile(filename2), "File 2 should not be deleted")
        self.assert_(not os.path.isfile(filename3), "File 3 should be deleted")
        self.assert_(os.path.isfile(filename4), "File 4 should not be deleted")

        Environment.cleanupTestFolder()

        # Let's do a test with weeks
        self.createFiles(files)
        self.setFileTime(filename1, time_now - timedelta(minutes=1))
        self.setFileTime(filename2, time_now - timedelta(weeks=1))
        self.setFileTime(filename3, time_now - timedelta(weeks=1, minutes=5))
        self.setFileTime(filename4, time_now - timedelta(weeks=3))

        RS = RetainStrategy('aStrat', timedelta(weeks=1), "week")
        RS.applyOnFiles(files)

        self.assert_(os.path.isfile(filename1), "File 1 should not be deleted")
        self.assert_(os.path.isfile(filename2), "File 2 should not be deleted")
        self.assert_(not os.path.isfile(filename3), "File 3 should be deleted")
        self.assert_(os.path.isfile(filename4), "File 4 should not be deleted")

        Environment.cleanupTestFolder()

        # Let's do a test with months
        self.createFiles(files)
        self.setFileTime(filename1, time_now - timedelta(minutes=1))
        self.setFileTime(filename2, time_now - timedelta(days=31))
        self.setFileTime(filename3, time_now - timedelta(days=31, minutes=5))
        self.setFileTime(filename4, time_now - timedelta(days=31 * 3))

        RS = RetainStrategy('aStrat', timedelta(days=31), "month")
        RS.applyOnFiles(files)

        self.assert_(os.path.isfile(filename1), "File 1 should not be deleted")
        self.assert_(os.path.isfile(filename2), "File 2 should not be deleted")
        self.assert_(not os.path.isfile(filename3), "File 3 should be deleted")
        self.assert_(os.path.isfile(filename4), "File 4 should not be deleted")

        Environment.cleanupTestFolder()

        # Finally let's do a test with years
        self.createFiles(files)
        self.setFileTime(filename1, time_now - timedelta(minutes=1))
        self.setFileTime(filename2, time_now - timedelta(days=365))
        self.setFileTime(filename3, time_now - timedelta(days=365, minutes=5))
        self.setFileTime(filename4, time_now - timedelta(days=365 * 3))

        RS = RetainStrategy('aStrat', timedelta(days=365), "year")
        RS.applyOnFiles(files)

        self.assert_(os.path.isfile(filename1), "File 1 should not be deleted")
        self.assert_(os.path.isfile(filename2), "File 2 should not be deleted")
        self.assert_(not os.path.isfile(filename3), "File 3 should be deleted")
        self.assert_(os.path.isfile(filename4), "File 4 should not be deleted")

        Environment.cleanupTestFolder()