mirror of
https://github.com/ckaczor/sqltoolsservice.git
synced 2026-01-14 01:25:40 -05:00
182 lines
8.6 KiB
C#
182 lines
8.6 KiB
C#
//
|
|
// Copyright (c) Microsoft. All rights reserved.
|
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
|
//
|
|
|
|
using Microsoft.SqlServer.Dac;
|
|
using Microsoft.SqlTools.ServiceLayer.DacFx;
|
|
using Microsoft.SqlTools.ServiceLayer.DacFx.Contracts;
|
|
using Microsoft.SqlTools.ServiceLayer.IntegrationTests.Utility;
|
|
using Microsoft.SqlTools.ServiceLayer.TaskServices;
|
|
using Microsoft.SqlTools.ServiceLayer.SchemaCompare.Contracts;
|
|
using Microsoft.SqlTools.ServiceLayer.Test.Common;
|
|
using NUnit.Framework;
|
|
using System;
|
|
using System.IO;
|
|
using static Microsoft.SqlTools.ServiceLayer.IntegrationTests.Utility.LiveConnectionHelper;
|
|
|
|
namespace Microsoft.SqlTools.ServiceLayer.IntegrationTests.SchemaCompare
|
|
{
|
|
internal static class SchemaCompareTestUtils
|
|
{
|
|
internal static void VerifyAndCleanup(string path)
|
|
{
|
|
// verify it was created...
|
|
Assert.True(File.Exists(path) || Directory.Exists(path), $"File or directory {path} was expected to exist but did not");
|
|
|
|
FileAttributes attr = File.GetAttributes(path);
|
|
|
|
// ...then clean it up
|
|
if ((attr & FileAttributes.Directory) == FileAttributes.Directory)
|
|
{
|
|
new DirectoryInfo(path).Delete(recursive: true);
|
|
}
|
|
else
|
|
{
|
|
File.Delete(path);
|
|
}
|
|
}
|
|
|
|
internal static string CreateDacpac(SqlTestDb testdb)
|
|
{
|
|
var result = GetLiveAutoCompleteTestObjects();
|
|
string folderPath = Path.Combine(Path.GetTempPath(), "SchemaCompareTest");
|
|
Directory.CreateDirectory(folderPath);
|
|
|
|
var extractParams = new ExtractParams
|
|
{
|
|
DatabaseName = testdb.DatabaseName,
|
|
PackageFilePath = Path.Combine(folderPath, string.Format("{0}.dacpac", testdb.DatabaseName)),
|
|
ApplicationName = "test",
|
|
ApplicationVersion = "1.0.0.0"
|
|
};
|
|
|
|
DacFxService service = new DacFxService();
|
|
ExtractOperation operation = new ExtractOperation(extractParams, result.ConnectionInfo);
|
|
service.PerformOperation(operation, TaskExecutionMode.Execute);
|
|
|
|
return extractParams.PackageFilePath;
|
|
}
|
|
|
|
internal static string CreateProject(SqlTestDb testdb, string projectName)
|
|
{
|
|
var result = GetLiveAutoCompleteTestObjects();
|
|
string folderPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), "SchemaCompareTest", projectName);
|
|
Directory.CreateDirectory(folderPath);
|
|
File.Create(Path.Combine(folderPath, projectName + ".sqlproj")).Close();
|
|
|
|
var extractParams = new ExtractParams
|
|
{
|
|
DatabaseName = testdb.DatabaseName,
|
|
ExtractTarget = DacExtractTarget.Flat,
|
|
PackageFilePath = folderPath,
|
|
ApplicationName = "test",
|
|
ApplicationVersion = "1.0.0.0"
|
|
};
|
|
|
|
DacFxService service = new();
|
|
ExtractOperation operation = new(extractParams, result.ConnectionInfo);
|
|
service.PerformOperation(operation, TaskExecutionMode.Execute);
|
|
|
|
return folderPath;
|
|
}
|
|
|
|
internal static string[] GetProjectScripts(string projectPath)
|
|
{
|
|
return Directory.GetFiles(projectPath, "*.sql", SearchOption.AllDirectories);
|
|
}
|
|
|
|
internal static string CreateScmpPath()
|
|
{
|
|
var result = GetLiveAutoCompleteTestObjects();
|
|
string folderPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), "SchemaCompareTest");
|
|
Directory.CreateDirectory(folderPath);
|
|
string fileName = TestContext.CurrentContext?.Test?.Name + "_" + DateTime.Now.Ticks.ToString();
|
|
|
|
string path = Path.Combine(folderPath, string.Format("{0}.scmp", fileName));
|
|
|
|
return path;
|
|
}
|
|
|
|
internal static LiveConnectionHelper.TestConnectionResult GetLiveAutoCompleteTestObjects()
|
|
{
|
|
// Adding retry for reliability - otherwise it caused test to fail in lab
|
|
TestConnectionResult result = null;
|
|
int retry = 3;
|
|
|
|
while (retry > 0)
|
|
{
|
|
result = LiveConnectionHelper.InitLiveConnectionInfo();
|
|
if (result != null && result.ConnectionInfo != null)
|
|
{
|
|
return result;
|
|
}
|
|
System.Threading.Thread.Sleep(1000);
|
|
retry--;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
internal static void CompareOptions(DeploymentOptions deploymentOptions, DacDeployOptions dacDeployOptions)
|
|
{
|
|
System.Reflection.PropertyInfo[] deploymentOptionsProperties = deploymentOptions.GetType().GetProperties();
|
|
System.Reflection.PropertyInfo[] dacDeployProperties = dacDeployOptions.GetType().GetProperties();
|
|
|
|
// Note that DatabaseSpecification and sql cmd variables list is not present in Sqltools service - its not settable with checkbox and is not used by ADS options.
|
|
// They are not present in SSDT as well
|
|
// TODO : update this test if the above options are added later
|
|
// TODO: update with new options. Tracking issue: https://github.com/microsoft/azuredatastudio/issues/15336
|
|
//Assert.True(deploymentOptionsProperties.Length == dacDeployProperties.Length - 2, $"Number of properties is not same Deployment options : {deploymentOptionsProperties.Length} DacFx options : {dacDeployProperties.Length}");
|
|
|
|
foreach (var deployOptionsProp in deploymentOptionsProperties)
|
|
{
|
|
var dacProp = dacDeployOptions.GetType().GetProperty(deployOptionsProp.Name);
|
|
Assert.True(dacProp != null, $"DacDeploy property not present for {deployOptionsProp.Name}");
|
|
|
|
var deployOptionsValue = deployOptionsProp.GetValue(deploymentOptions);
|
|
var changedDacValue = deployOptionsValue != null ? deployOptionsValue.GetType().GetProperty("Value").GetValue(deployOptionsValue) : deployOptionsValue;
|
|
var dafaultDacValue = dacProp.GetValue(dacDeployOptions);
|
|
|
|
if (deployOptionsProp.Name != "ExcludeObjectTypes") // do not compare for ExcludeObjectTypes because it will be different
|
|
{
|
|
Assert.True((deployOptionsValue == null && dafaultDacValue == null)
|
|
|| deployOptionsValue.Equals(dafaultDacValue)
|
|
|| changedDacValue == null && (dafaultDacValue as string) == string.Empty
|
|
|| changedDacValue == null && dafaultDacValue == null
|
|
|| (changedDacValue).Equals(dafaultDacValue)
|
|
, $"DacFx DacDeploy property not equal to Tools Service DeploymentOptions for { deployOptionsProp.Name}, SchemaCompareOptions value: {changedDacValue} and DacDeployOptions value: {dafaultDacValue} ");
|
|
}
|
|
}
|
|
}
|
|
|
|
internal static bool ValidateOptionsEqualsDefault(SchemaCompareOptionsResult options)
|
|
{
|
|
DeploymentOptions defaultOpt = new DeploymentOptions();
|
|
DeploymentOptions actualOpt = options.DefaultDeploymentOptions;
|
|
|
|
System.Reflection.PropertyInfo[] deploymentOptionsProperties = defaultOpt.GetType().GetProperties();
|
|
foreach (var v in deploymentOptionsProperties)
|
|
{
|
|
var defaultP = v.GetValue(defaultOpt);
|
|
var defaultPValue = defaultP != null ? defaultP.GetType().GetProperty("Value").GetValue(defaultP) : defaultP;
|
|
var actualP = v.GetValue(actualOpt);
|
|
var actualPValue = actualP.GetType().GetProperty("Value").GetValue(actualP);
|
|
|
|
if (v.Name == "ExcludeObjectTypes")
|
|
{
|
|
Assert.True((defaultPValue as ObjectType[]).Length == (actualPValue as ObjectType[]).Length, $"Number of excluded objects is different; expected: {(defaultPValue as ObjectType[]).Length} actual: {(actualPValue as ObjectType[]).Length}");
|
|
}
|
|
else
|
|
{
|
|
// Verifying expected and actual deployment options properties are equal
|
|
Assert.True((defaultPValue == null && String.IsNullOrEmpty(actualPValue as string))
|
|
|| (defaultPValue).Equals(actualPValue)
|
|
, $"Actual Property from Service is not equal to default property for {v.Name}, Actual value: {actualPValue} and Default value: {defaultPValue}");
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
}
|
|
}
|