mirror of
https://github.com/ckaczor/sqltoolsservice.git
synced 2026-01-14 01:25:40 -05:00
* Adding recommendations * Adding raw graph type in execution plan graph contracts * Fixing function name and concising string formatting * Converting localized string to a function * Using better names in contract props Formatting names in a better way * Getting rid of unnecessary getter, setters and private props * Fixing localized strings, comments and imports * Fixing some contracts * Fixing csproj formatting * Fixing var names * Fixing xml comments
65 lines
2.7 KiB
C#
65 lines
2.7 KiB
C#
using System;
|
|
//
|
|
// Copyright (c) Microsoft. All rights reserved.
|
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
|
//
|
|
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
using System.Reflection;
|
|
using NUnit.Framework;
|
|
using Microsoft.SqlTools.ServiceLayer.ShowPlan;
|
|
|
|
|
|
namespace Microsoft.SqlTools.ServiceLayer.UnitTests.ShowPlan
|
|
{
|
|
public class ShowPlanXMLTests
|
|
{
|
|
private string queryPlanFileText;
|
|
|
|
[Test]
|
|
public void ParseXMLFileReturnsValidShowPlanGraph()
|
|
{
|
|
ReadFile(".ShowPlan.TestExecutionPlan.xml");
|
|
var showPlanGraphs = ShowPlanGraphUtils.CreateShowPlanGraph(queryPlanFileText, "testFile.sql");
|
|
Assert.AreEqual(1, showPlanGraphs.Count, "exactly one show plan graph should be returned");
|
|
Assert.NotNull(showPlanGraphs[0], "graph should not be null");
|
|
Assert.NotNull(showPlanGraphs[0].Root, "graph should have a root");
|
|
}
|
|
|
|
[Test]
|
|
public void ParsingNestedProperties()
|
|
{
|
|
ReadFile(".ShowPlan.TestExecutionPlan.xml");
|
|
string[] commonNestedPropertiesNames = { "MemoryGrantInfo", "OptimizerHardwareDependentProperties" };
|
|
var showPlanGraphs = ShowPlanGraphUtils.CreateShowPlanGraph(queryPlanFileText, "testFile.sql");
|
|
ExecutionPlanNode rootNode = showPlanGraphs[0].Root;
|
|
rootNode.Properties.ForEach(p =>
|
|
{
|
|
if (Array.FindIndex(commonNestedPropertiesNames, i => i.Equals(p.Name)) != -1 && (NestedExecutionPlanGraphProperty)p != null)
|
|
{
|
|
Assert.NotZero(((NestedExecutionPlanGraphProperty)p).Value.Count);
|
|
}
|
|
});
|
|
}
|
|
|
|
[Test]
|
|
public void ParseXMLFileWithRecommendations()
|
|
{
|
|
//The first graph in this execution plan has 3 recommendations
|
|
ReadFile(".ShowPlan.TestExecutionPlanRecommendations.xml");
|
|
string[] commonNestedPropertiesNames = { "MemoryGrantInfo", "OptimizerHardwareDependentProperties" };
|
|
var showPlanGraphs = ShowPlanGraphUtils.CreateShowPlanGraph(queryPlanFileText, "testFile.sql");
|
|
List<ExecutionPlanRecommendation> rootNode = showPlanGraphs[0].Recommendations;
|
|
Assert.AreEqual(3, rootNode.Count, "3 recommendations should be returned by the showplan parser");
|
|
}
|
|
|
|
private void ReadFile(string fileName)
|
|
{
|
|
Assembly assembly = Assembly.GetAssembly(typeof(ShowPlanXMLTests));
|
|
Stream scriptStream = assembly.GetManifestResourceStream(assembly.GetName().Name + fileName);
|
|
StreamReader reader = new StreamReader(scriptStream);
|
|
queryPlanFileText = reader.ReadToEnd();
|
|
}
|
|
}
|
|
} |