Exemplo n.º 1
0
        private static void CreateAndKeepRemoveFolderHeld(string folderName, TimeSpan timeToHold)
        {
            ContainerManagerTests.CreateContainerFoldersWithFiles(new string[] { folderName }, emptyFolderMarkerFilesList);

            StreamWriter fileHolder = File.CreateText(Path.Combine(mockContainerEnvironment.Object.ContainerLogRootDirectory, folderName, ContainerEnvironment.ContainerRemoveLogMarkerFileName));

            Thread.Sleep((int)timeToHold.TotalMilliseconds);
            fileHolder.Dispose();
        }
Exemplo n.º 2
0
 private static void CreateContainerFoldersWithFiles(IEnumerable <string> foldersFullPath, IEnumerable <string> fileNamesInsideFolder)
 {
     foreach (string containerName in foldersFullPath)
     {
         string path = Path.Combine(ContainerManagerTests.mockContainerEnvironment.Object.ContainerLogRootDirectory, containerName);
         Directory.CreateDirectory(path);
         ContainerManagerTests.CreateFilesInsideFolder(path, fileNamesInsideFolder);
     }
 }
Exemplo n.º 3
0
        private static void CreateFilesInsideFoldersWithSuffix(string folderPath, string folderNameSuffix, IEnumerable <string> fileNames)
        {
            List <string> foldersToAddFiles = new List <string>();

            var folders = Directory.EnumerateDirectories(folderPath);

            foreach (string folder in folders)
            {
                string folderName = Path.GetFileName(folder);
                if (folderName.EndsWith(folderNameSuffix, StringComparison.Ordinal))
                {
                    foldersToAddFiles.Add(folder);
                }
            }

            foreach (string folder in foldersToAddFiles)
            {
                ContainerManagerTests.CreateFilesInsideFolder(folder, fileNames);
            }
        }
Exemplo n.º 4
0
        private static void CreateProcessRemoveFolders(string folderNameSuffix, int numberOfEmptyFolders)
        {
            IEnumerable <string> folderNames = ContainerManagerTests.CreateContainerFolderNames(folderNameSuffix, numberOfEmptyFolders);

            ContainerManagerTests.CreateContainerFoldersWithFiles(folderNames, ContainerManagerTests.processRemoveFolderMarkerFileList);
        }
Exemplo n.º 5
0
        private static void ContainerManagerStartupAndFileCreationTest(string logFolderNameForTest, TimeSpan cleanupTimeInterval, TimeSpan maxWaitProcessingTime, int numberOfEachFolderType)
        {
            // variables to control the time given to portions of the test to finish its tasks.
            // this are used with cleanupTimeInterval and the numberOfFolders below
            int threadCleanupWaitTimeMultiplier = 5;
            int threadWaitTimeMultiplier        = 15;

            int numberOfEmptyFolders         = numberOfEachFolderType * 2;
            int numberOfProcessFolders       = numberOfEachFolderType;
            int numberOfRemoveFolders        = numberOfEachFolderType;
            int numberOfProcessRemoveFolders = numberOfEachFolderType;

            string emptyFolderNameSuffix         = "sf-empty-startup";
            string processFolderNameSuffix       = "sf-process-startup";
            string removeFolderNameSuffix        = "sf-remove-startup";
            string processRemoveFolderNameSuffix = "sf-process-remove-startup";

            // setting up mock ContainerEnvironment
            ContainerManagerTests.SetMockLogContainerFolder(logFolderNameForTest);
            ContainerManagerTests.SetMockCleanupAndMaxWaitProcessingTimes(
                cleanupTimeInterval,
                maxWaitProcessingTime);

            // cleanup any folders from previous test
            if (Directory.Exists(ContainerManagerTests.mockContainerEnvironment.Object.ContainerLogRootDirectory))
            {
                Directory.Delete(ContainerManagerTests.mockContainerEnvironment.Object.ContainerLogRootDirectory, true);
            }

            // Creating initial folders before starting testing
            ContainerManagerTests.CreateEmptyFolders(emptyFolderNameSuffix, numberOfEmptyFolders);
            ContainerManagerTests.CreateProcessFolders(processFolderNameSuffix, numberOfProcessFolders);
            ContainerManagerTests.CreateRemoveFolders(removeFolderNameSuffix, numberOfRemoveFolders);

            // Creating the last batch of folders in parallel to test the race condition in startup of ContainerManager
            // with its file watchers and initial listing of folders
            Task createFolders = Task.Run(() =>
            {
                ContainerManagerTests.CreateProcessRemoveFolders(processRemoveFolderNameSuffix, numberOfProcessRemoveFolders);
            });

            ContainerManager containerManager = new ContainerManager(
                ContainerManagerTests.mockAppInstanceManager.Object,
                ContainerManagerTests.mockContainerEnvironment.Object);

            createFolders.Wait();

            // wait for a few cycles of cleanup which should give enough time for finishing removing folders still processing.
            Thread.Sleep(threadCleanupWaitTimeMultiplier * (int)cleanupTimeInterval.TotalMilliseconds);

            // Testing if the number of AppInstances is correct and the number of folders is expected.
            Assert.AreEqual(numberOfProcessFolders, ContainerManagerTests.appInstances.Count);
            Assert.AreEqual(numberOfProcessFolders + numberOfEmptyFolders, ContainerManagerTests.GetNumberOfContainerFolders());

            // start processing empty folders this should increase the number of appInstances
            ContainerManagerTests.CreateFilesInsideFoldersWithSuffix(
                mockContainerEnvironment.Object.ContainerLogRootDirectory,
                emptyFolderNameSuffix,
                processFolderMarkerFilesList);

            // giving some time to process all callbacks for file created
            Thread.Sleep(numberOfEmptyFolders * threadWaitTimeMultiplier);

            Assert.AreEqual(numberOfProcessFolders + numberOfEmptyFolders, ContainerManagerTests.appInstances.Count);
            Assert.AreEqual(numberOfProcessFolders + numberOfEmptyFolders, ContainerManagerTests.GetNumberOfContainerFolders());

            // flag all empty folders (not empty at this point) for deletion
            ContainerManagerTests.CreateFilesInsideFoldersWithSuffix(
                mockContainerEnvironment.Object.ContainerLogRootDirectory,
                emptyFolderNameSuffix,
                removeFolderMarkerFileList);

            // flag all process folders for removal
            ContainerManagerTests.CreateFilesInsideFoldersWithSuffix(
                mockContainerEnvironment.Object.ContainerLogRootDirectory,
                processFolderNameSuffix,
                removeFolderMarkerFileList);

            // giving some time to process all callbacks for file created
            Thread.Sleep((numberOfEmptyFolders + numberOfProcessFolders) * threadWaitTimeMultiplier + threadCleanupWaitTimeMultiplier * (int)cleanupTimeInterval.TotalMilliseconds);

            Assert.AreEqual(0, ContainerManagerTests.appInstances.Count);
            Assert.AreEqual(0, ContainerManagerTests.GetNumberOfContainerFolders());

            // Creating folders to be immediately removed and adding a handle to file to prevent it from being removed initially.
            ContainerManagerTests.CreateRemoveFolders(removeFolderNameSuffix, numberOfRemoveFolders);

            ContainerManagerTests.CreateAndKeepRemoveFolderHeld("temp-held-folder", TimeSpan.FromSeconds(2));

            Thread.Sleep((numberOfRemoveFolders) * threadWaitTimeMultiplier + threadCleanupWaitTimeMultiplier * (int)cleanupTimeInterval.TotalMilliseconds);

            Assert.AreEqual(0, ContainerManagerTests.appInstances.Count);
            Assert.AreEqual(0, ContainerManagerTests.GetNumberOfContainerFolders());

            // Creating folders to be processed and removed
            ContainerManagerTests.CreateProcessRemoveFolders(processRemoveFolderNameSuffix, numberOfProcessRemoveFolders);
            Thread.Sleep((numberOfProcessRemoveFolders) * threadWaitTimeMultiplier + threadCleanupWaitTimeMultiplier * (int)cleanupTimeInterval.TotalMilliseconds);

            Assert.AreEqual(0, ContainerManagerTests.appInstances.Count);
            Assert.AreEqual(0, ContainerManagerTests.GetNumberOfContainerFolders());
        }