如何:为诊断数据适配器创建自定义数据编辑器
发布时间: 2016年7月
创建诊断数据适配器后,您可能希望在用户选择您的自定义诊断数据适配器用于测试设置时,用户能够配置特定数据。 例如,您可以选择配置数据,这些配置数据指定要提取的注册表项、要模拟的网络负载级别、存储临时文件或要附加的工作文件的目录。
您必须使用配置文件来设置您的诊断数据适配器的初始值。 可提供自定义编辑器以使用户能够修改配置数据。
若要创建您自己的编辑器,则需要创建实现 IDataCollectorConfigurationEditor 的用户控件。
诊断数据适配器可使用 DataCollectorConfigurationEditorAttribute 来指定要用于编辑诊断数据配置设置的编辑器类。
还可以指定要使用的默认配置数据。有关默认配置的示例,请参见用于创建诊断数据适配器的示例项目。
使用自定义诊断数据适配器时,执行以下过程可创建自定义编辑器来更新测试设置的数据。
备注
若要创建自定义编辑器,必须首先创建诊断数据适配器,其中对类应用了 DataCollectorConfigurationEditorAttribute。可以在该特性中使用可选 HelpUri 属性,以指定编辑器的帮助内容源。有关如何创建诊断数据适配器的更多信息,请参见如何:创建诊断数据适配器。
有关诊断数据适配器项目(包括自定义配置编辑器)的完整示例,请参见用于创建诊断数据适配器的示例项目。
为诊断数据适配器创建自定义编辑器
为诊断数据适配器创建自定义编辑器
在诊断数据适配器的项目中创建用户控件:
右击包含诊断数据适配器类的代码项目,指向**“添加”,再指向“用户控件”**。
在此示例中,向窗体中添加具有文本:“Data File Name:”的标签和名为“FileTextBox”的文本框,以使用户能输入必要的数据。
备注
目前仅支持 Windows 窗体用户控件。
将这些行添加到声明部分:
using System.Xml; using Microsoft.VisualStudio.TestTools.Common; using Microsoft.VisualStudio.TestTools.Execution;
使此用户控件成为自定义编辑器。
在您的代码项目中右击该用户控件,然后指向**“查看代码”**。
如下所示设置该类,以实现编辑器接口 IDataCollectorConfigurationEditor:
public partial class MyDataConfigEditor : UserControl, IDataCollectorConfigurationEditor
右击代码中的 IDataCollectorConfigurationEditor,再选择**“实现接口”**命令。 您必须为此接口实现的方法将添加到该类中。
将 DataCollectorConfigurationEditorAttribute 添加到编辑器用户控件中以将它标识为诊断数据适配器编辑器,用您的诊断数据适配器的相应信息来替换**“公司”、“产品”和“版本”**:
[DataCollectorConfigurationEditorTypeUri( "configurationeditor://MyCompany/MyConfigEditor/1.0")]
添加两个私有变量,如下所示:
private DataCollectorSettings collectorSettings; private IServiceProvider ServiceProvider { get; set; }
添加代码以初始化诊断数据适配器的编辑器。 可使用设置变量中的数据向用户控件中的字段添加默认值。 此数据位于适配器的 XML 配置文件的 <DefaultConfiguration> 元素中。
public void Initialize( IServiceProvider svcProvider, DataCollectorSettings settings) { ServiceProvider = svcProvider; collectorSettings = settings; // Display the default file name as listed in the settings file. this.SuspendLayout(); this.FileTextBox.Text = getText(collectorSettings.Configuration); this.ResumeLayout(); }
添加代码以将来自编辑器中控件的数据存回诊断数据适配器 API 所需的 XML 格式,如下所示:
public DataCollectorSettings SaveData() { collectorSettings.Configuration.InnerXml = String.Format( @"<MyCollectorName http://MyCompany/schemas/MyDiagnosticDataCollector/1.0""> <File FullPath=""{0}"" /> </MyCollectorName>", FileTextBox.Text); return collectorSettings; }
如果这对您很重要,请在 VerifyData 方法中添加代码以验证数据是否正确,也可以直接使该方法返回 true。
public bool VerifyData() { // Not currently verifying data return true; }
(可选)可以在 ResetToAgentDefaults() 方法(该方法使用专用 getText() 方法)中添加代码,以将数据重置为 XML 配置文件中提供的初始设置。
// Reset to default value from XML configuration // using a custom getText() method public void ResetToAgentDefaults() { this.FileTextBox.Text = getText(collectorSettings.DefaultConfiguration); } // Local method to read the configuration settings private string getText(XmlElement element) { // Setup namespace manager with our namespace XmlNamespaceManager nsmgr = new XmlNamespaceManager( element.OwnerDocument.NameTable); // Find all the "File" elements under our configuration XmlNodeList files = element.SelectNodes("//ns:MyCollectorName/ns:File", nsmgr); string result = String.Empty; if (files.Count > 0) { XmlAttribute pathAttribute = files[0].Attributes["FullPath"]; if (pathAttribute != null && !String.IsNullOrEmpty(pathAttribute.Value)) { result = pathAttribute.Value; } } return result; }
生成解决方案。 将诊断数据适配器程序集和 XML 配置文件 (<diagnostic data adapter name>.dll.config) 复制到基于您的安装目录的以下位置:Program Files\Microsoft Visual Studio 12.0\Common7\IDE\PrivateAssemblies\DataCollectors。
备注
虽然配置编辑器与诊断数据适配器可位于不同的项目和程序集中,但它们也可位于同一程序集中。
若要使用正在测试的诊断数据适配器,您必须从现有测试设置列表中进行选择,或者从 Microsoft 测试管理器或 Visual Studio 创建一个新的诊断数据适配器,然后选择它。
该适配器将显示在测试设置的**“数据和诊断”**选项卡上,并具有您指派给该类的友好名称。
若要为您的测试设置配置诊断数据适配器,请选择适配器名称旁的**“配置”**。
此时将显示您的自定义编辑器。
根据需要编辑自定义编辑器中的字段,然后选择**“保存”**。
如果您是从 Microsoft 测试管理器运行测试,则可以在运行测试前将这些测试设置分配给测试计划,也可以使用**“使用选项运行”**命令分配测试设置并重写测试设置。 有关测试设置的更多信息,请参见使用测试设置来设置计算机和收集诊断信息。
在将您的新配置编辑器与诊断数据适配器一起使用之前,必须先将 DataCollectorConfigurationEditorAttribute 应用于要使用该编辑器的每个诊断数据适配器类,然后在客户端计算机上重新编译并重新安装它们。 有关安装诊断数据适配器和配置编辑器的更多信息,请参见如何:安装自定义诊断数据适配器。
使用选择了您的诊断数据适配器的测试设置运行测试。
您在编辑器中指定的数据文件将被附加到测试结果中。
有关如何配置测试设置,以便在运行测试时使用环境的更多信息,请参见在手动测试中收集更多诊断数据或使用 Microsoft 测试管理器为自动系统测试创建测试设置。
请参阅
IDataCollectorConfigurationEditor
DataCollectorConfigurationEditorAttribute
DataCollectorConfigurationEditorAttribute
创建诊断数据适配器以收集自定义数据或影响测试计算机
使用测试设置来设置计算机和收集诊断信息
用于创建诊断数据适配器的示例项目