mirror of
https://github.com/ckaczor/sqltoolsservice.git
synced 2026-01-14 01:25:40 -05:00
3278 Kusto Unit Tests - Part 2 (#1063)
* 3278 Added unit tests in MetadataFactoryTests and Microsoft.Kusto.ServiceLayer.UnitTests project * 3278 Removed todo and changed unit test to validate megabytes * 3278 Added file and unit tests in AutoCompleteHelperTests.cs * 3278 Removed unused functions from Kusto > ScriptAsScriptingOperation * 3278 Added unit tests for DataSourceFactory * 3278 Refactored AdminService to pass in ConnectionService rather than through instance variable. Added unit test for AdminServiceTests * 3278 Refactored DataSourceFactory to not have static functions for future unit tests * 3278 Re-added properties that were flagged as unused but are being used by ADS in ReliableDataSourceConnection.cs * 3278 Re-added properties that were flagged as unused but are being used by ADS in ReliableDataSourceConnection.cs * adding pipeline to execute tests (#1062) * 3278 Converted GetDefaultAutoComplete and GetDefaultSemanticMarkers to static functions in DataSourceFactory. Removed unused constructor in ScriptFile. Added positive unit tests for both functions * undoing release version bump * adding additional configs * 3278 Minor refactors in ConnectionInfo, BindingQueue, DiagnosticsHelper, MetadataService, and HostLoader. Changed AssemblyInfo to only allow Kusto Unit Tests for internal access. Added lots of unit tests. * 3278 Commented out bindingContext.IsConnected in AddConnectionContext_Sets_BindingContext * 3278 Reversed order of unit tests in ConnectedBindingQueueTests and added throw to Catch block. * 3278 Reverted change to ConnectedBindingQueue. Removed unit test from AddConnectionContext for NeedsMetaData True Co-authored-by: Jorge Berumen <52225468+joberume@users.noreply.github.com> Co-authored-by: joberume <jberumen3@miners.utep.edu>
This commit is contained in:
@@ -0,0 +1,57 @@
|
||||
using Microsoft.Kusto.ServiceLayer.DataSource;
|
||||
using Microsoft.Kusto.ServiceLayer.Scripting;
|
||||
using Microsoft.Kusto.ServiceLayer.Scripting.Contracts;
|
||||
using Microsoft.SqlServer.Management.Sdk.Sfc;
|
||||
using Moq;
|
||||
using NUnit.Framework;
|
||||
|
||||
namespace Microsoft.Kusto.ServiceLayer.UnitTests.Scripting
|
||||
{
|
||||
public class ScripterTests
|
||||
{
|
||||
[Test]
|
||||
public void SelectFromTableOrView_Returns_SelectQuery()
|
||||
{
|
||||
var mockDataSource = new Mock<IDataSource>();
|
||||
var urn = new Urn(@"Server[@Name = 'SERVER']/Database[@Name = 'quoted''db']/Table[@Name = 'quoted''Name' and @Schema = 'quoted''Schema']");
|
||||
var scripter = new Scripter();
|
||||
var result = scripter.SelectFromTableOrView(mockDataSource.Object, urn);
|
||||
|
||||
Assert.AreEqual("[@\"quoted'Name\"]\n | limit 1000", result);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void AlterFunction()
|
||||
{
|
||||
var expected = "AlterScript";
|
||||
var mockDataSource = new Mock<IDataSource>();
|
||||
mockDataSource.Setup(x => x.GenerateAlterFunctionScript(It.IsAny<string>())).Returns(expected);
|
||||
|
||||
var scriptingObject = new ScriptingObject
|
||||
{
|
||||
Name = "Name(a:int, b: int)"
|
||||
};
|
||||
var scripter = new Scripter();
|
||||
var result = scripter.AlterFunction(mockDataSource.Object, scriptingObject);
|
||||
|
||||
Assert.AreEqual(expected, result);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void ExecuteFunction()
|
||||
{
|
||||
var expected = "ExecuteScript";
|
||||
var mockDataSource = new Mock<IDataSource>();
|
||||
mockDataSource.Setup(x => x.GenerateExecuteFunctionScript(It.IsAny<string>())).Returns(expected);
|
||||
|
||||
var scriptingObject = new ScriptingObject
|
||||
{
|
||||
Name = "Name(a:int, b: int)"
|
||||
};
|
||||
var scripter = new Scripter();
|
||||
var result = scripter.ExecuteFunction(mockDataSource.Object, scriptingObject);
|
||||
|
||||
Assert.AreEqual(expected, result);
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user