【问题标题】:Restoring file system hierarchy from file从文件恢复文件系统层次结构
【发布时间】:2019-02-09 06:12:40
【问题描述】:

我正在创建文件管理应用程序(在 .NET 中),它可以复制、移动和删除文件和目录。我想为它编写性能测试。为此,我需要在每次测试之前重新创建目录和文件层次结构。我想将此层次结构存储在一个文件中,以便将其保存在存储库中。只要我能定义文件大小、修改日期等,我不关心文件的内容。

现在我的问题。有没有可以帮助我的应用程序/框架?如果它有 GUI 来定义层次结构(如 Windows 资源管理器),那就太棒了,因为处理包含数千条记录的文本文件很痛苦。

【问题讨论】:

    标签: c# .net filesystems performance-testing


    【解决方案1】:

    这是一个以 xml 格式存储文件系统的程序:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Xml;
    using System.Xml.Linq;
    using System.IO;
    
    namespace SAveDirectoriesXml
    {
        class Program
        {
            const string FILENAME = @"c:\temp\test.xml";
            const string FOLDER = @"c:\temp";
            static XmlWriter writer = null;
            static void Main(string[] args)
            {
                XmlWriterSettings settings = new XmlWriterSettings();
                settings.Indent = true;
    
                writer = XmlWriter.Create(FILENAME, settings);
                writer.WriteStartDocument(true);
    
                DirectoryInfo info = new DirectoryInfo(FOLDER);
                WriteTree(info);
    
                writer.WriteEndDocument();
                writer.Flush();
                writer.Close();
                Console.WriteLine("Enter Return");
                Console.ReadLine();
    
            }
            static long WriteTree(DirectoryInfo info)
            {
                long size = 0;
                writer.WriteStartElement("Folder");
                try
                {
                    writer.WriteAttributeString("name", info.Name);
                    writer.WriteAttributeString("numberSubFolders", info.GetDirectories().Count().ToString());
                    writer.WriteAttributeString("numberFiles", info.GetFiles().Count().ToString());
                    writer.WriteAttributeString("date", info.LastWriteTime.ToString());
    
    
                    foreach (DirectoryInfo childInfo in info.GetDirectories())
                    {
                        size += WriteTree(childInfo);
                    }
    
                }
                catch (Exception ex)
                {
                    string errorMsg = string.Format("Exception Folder : {0}, Error : {1}", info.FullName, ex.Message);
                    Console.WriteLine(errorMsg);
                    writer.WriteElementString("Error", errorMsg);
                }
    
                FileInfo[] fileInfo = null;
                try
                {
                    fileInfo = info.GetFiles();
                }
                catch (Exception ex)
                {
                    string errorMsg = string.Format("Exception FileInfo : {0}, Error : {1}", info.FullName, ex.Message);
                    Console.WriteLine(errorMsg);
                    writer.WriteElementString("Error",errorMsg);
                }
    
                if (fileInfo != null)
                {
                    foreach (FileInfo finfo in fileInfo)
                    {
                        try
                        {
                            writer.WriteStartElement("File");
                            writer.WriteAttributeString("name", finfo.Name);
                            writer.WriteAttributeString("size", finfo.Length.ToString());
                            writer.WriteAttributeString("date", info.LastWriteTime.ToString());
                            writer.WriteEndElement();
                            size += finfo.Length;
                        }
                        catch (Exception ex)
                        {
                            string errorMsg = string.Format("Exception File : {0}, Error : {1}", finfo.FullName, ex.Message);
                            Console.WriteLine(errorMsg);
                            writer.WriteElementString("Error", errorMsg);
                        }
                    }
                }
    
                writer.WriteElementString("size", size.ToString());
                writer.WriteEndElement();
                return size;
    
            }
        }
    }
    

    【讨论】:

    • 这不是我真正希望的,因为它只解决了我的问题的一小部分,但假设没有其他响应意味着没有更好的可用。谢谢!
    • 您可以将结构放入树视图(或自定义对话框)中,使其看起来类似于资源管理器。 Codeproject 有许多自定义对话框可能会有所帮助。
    【解决方案2】:

    我可能遗漏了您的一些要求,但我过去所做的只是创建一个 zip 文件(或 tar、7z 等),其中包含我的测试所期望的文件和文件夹结构,并拥有它存档已签入我们的源代码控制存储库。

    然后我可以在每次测试之前将该存档提取到一个临时文件夹,并将我的测试指向它。之后,只需删除临时文件夹,以便下一次测试可以重新开始。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-01-09
      相关资源
      最近更新 更多