mirror of
https://github.com/ckaczor/sqltoolsservice.git
synced 2026-02-16 10:58:30 -05:00
Move Integration Tests to dedicated project (#201)
Add IntegrationTests project. Move all tests ifdef'd with LIVE_CONNECTION_TESTS to IntegrationTests project. Delete files that have no remaining code. Update codecoverage.bat to run integration tests
This commit is contained in:
@@ -53,28 +53,45 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "CodeCoverage", "CodeCoverag
|
|||||||
EndProject
|
EndProject
|
||||||
Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "Microsoft.SqlTools.ServiceLayer.PerfTests", "test\Microsoft.SqlTools.ServiceLayer.PerfTests\Microsoft.SqlTools.ServiceLayer.PerfTests.xproj", "{7E5968AB-83D7-4738-85A2-416A50F13D2F}"
|
Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "Microsoft.SqlTools.ServiceLayer.PerfTests", "test\Microsoft.SqlTools.ServiceLayer.PerfTests\Microsoft.SqlTools.ServiceLayer.PerfTests.xproj", "{7E5968AB-83D7-4738-85A2-416A50F13D2F}"
|
||||||
EndProject
|
EndProject
|
||||||
|
Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "Microsoft.SqlTools.ServiceLayer.IntegrationTests", "test\Microsoft.SqlTools.ServiceLayer.IntegrationTests\Microsoft.SqlTools.ServiceLayer.IntegrationTests.xproj", "{08AF0209-D598-47BB-9DFD-FC9E74C0FE56}"
|
||||||
|
EndProject
|
||||||
Global
|
Global
|
||||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
Debug|Any CPU = Debug|Any CPU
|
Debug|Any CPU = Debug|Any CPU
|
||||||
|
Integration|Any CPU = Integration|Any CPU
|
||||||
Release|Any CPU = Release|Any CPU
|
Release|Any CPU = Release|Any CPU
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
{0D61DC2B-DA66-441D-B9D0-F76C98F780F9}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
{0D61DC2B-DA66-441D-B9D0-F76C98F780F9}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
{0D61DC2B-DA66-441D-B9D0-F76C98F780F9}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
{0D61DC2B-DA66-441D-B9D0-F76C98F780F9}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{0D61DC2B-DA66-441D-B9D0-F76C98F780F9}.Integration|Any CPU.ActiveCfg = Integration|Any CPU
|
||||||
|
{0D61DC2B-DA66-441D-B9D0-F76C98F780F9}.Integration|Any CPU.Build.0 = Integration|Any CPU
|
||||||
{0D61DC2B-DA66-441D-B9D0-F76C98F780F9}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
{0D61DC2B-DA66-441D-B9D0-F76C98F780F9}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{0D61DC2B-DA66-441D-B9D0-F76C98F780F9}.Release|Any CPU.Build.0 = Release|Any CPU
|
{0D61DC2B-DA66-441D-B9D0-F76C98F780F9}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
{2D771D16-9D85-4053-9F79-E2034737DEEF}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
{2D771D16-9D85-4053-9F79-E2034737DEEF}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
{2D771D16-9D85-4053-9F79-E2034737DEEF}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
{2D771D16-9D85-4053-9F79-E2034737DEEF}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{2D771D16-9D85-4053-9F79-E2034737DEEF}.Integration|Any CPU.ActiveCfg = Integration|Any CPU
|
||||||
|
{2D771D16-9D85-4053-9F79-E2034737DEEF}.Integration|Any CPU.Build.0 = Integration|Any CPU
|
||||||
{2D771D16-9D85-4053-9F79-E2034737DEEF}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
{2D771D16-9D85-4053-9F79-E2034737DEEF}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{2D771D16-9D85-4053-9F79-E2034737DEEF}.Release|Any CPU.Build.0 = Release|Any CPU
|
{2D771D16-9D85-4053-9F79-E2034737DEEF}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
{CC785604-6277-4878-8DA9-360C47158E96}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
{CC785604-6277-4878-8DA9-360C47158E96}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
{CC785604-6277-4878-8DA9-360C47158E96}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
{CC785604-6277-4878-8DA9-360C47158E96}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{CC785604-6277-4878-8DA9-360C47158E96}.Integration|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{CC785604-6277-4878-8DA9-360C47158E96}.Integration|Any CPU.Build.0 = Release|Any CPU
|
||||||
{CC785604-6277-4878-8DA9-360C47158E96}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
{CC785604-6277-4878-8DA9-360C47158E96}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{CC785604-6277-4878-8DA9-360C47158E96}.Release|Any CPU.Build.0 = Release|Any CPU
|
{CC785604-6277-4878-8DA9-360C47158E96}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
{7E5968AB-83D7-4738-85A2-416A50F13D2F}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
{7E5968AB-83D7-4738-85A2-416A50F13D2F}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
{7E5968AB-83D7-4738-85A2-416A50F13D2F}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
{7E5968AB-83D7-4738-85A2-416A50F13D2F}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{7E5968AB-83D7-4738-85A2-416A50F13D2F}.Integration|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{7E5968AB-83D7-4738-85A2-416A50F13D2F}.Integration|Any CPU.Build.0 = Release|Any CPU
|
||||||
{7E5968AB-83D7-4738-85A2-416A50F13D2F}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
{7E5968AB-83D7-4738-85A2-416A50F13D2F}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{7E5968AB-83D7-4738-85A2-416A50F13D2F}.Release|Any CPU.Build.0 = Release|Any CPU
|
{7E5968AB-83D7-4738-85A2-416A50F13D2F}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
{08AF0209-D598-47BB-9DFD-FC9E74C0FE56}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{08AF0209-D598-47BB-9DFD-FC9E74C0FE56}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{08AF0209-D598-47BB-9DFD-FC9E74C0FE56}.Integration|Any CPU.ActiveCfg = Integration|Any CPU
|
||||||
|
{08AF0209-D598-47BB-9DFD-FC9E74C0FE56}.Integration|Any CPU.Build.0 = Integration|Any CPU
|
||||||
|
{08AF0209-D598-47BB-9DFD-FC9E74C0FE56}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{08AF0209-D598-47BB-9DFD-FC9E74C0FE56}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(SolutionProperties) = preSolution
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
HideSolutionNode = FALSE
|
HideSolutionNode = FALSE
|
||||||
@@ -86,5 +103,6 @@ Global
|
|||||||
{B7D21727-2926-452B-9610-3ADB0BB6D789} = {F9978D78-78FE-4E92-A7D6-D436B7683EF6}
|
{B7D21727-2926-452B-9610-3ADB0BB6D789} = {F9978D78-78FE-4E92-A7D6-D436B7683EF6}
|
||||||
{87D9C7D9-18F4-4AB9-B20D-66C02B6075E2} = {AB9CA2B8-6F70-431C-8A1D-67479D8A7BE4}
|
{87D9C7D9-18F4-4AB9-B20D-66C02B6075E2} = {AB9CA2B8-6F70-431C-8A1D-67479D8A7BE4}
|
||||||
{7E5968AB-83D7-4738-85A2-416A50F13D2F} = {AB9CA2B8-6F70-431C-8A1D-67479D8A7BE4}
|
{7E5968AB-83D7-4738-85A2-416A50F13D2F} = {AB9CA2B8-6F70-431C-8A1D-67479D8A7BE4}
|
||||||
|
{08AF0209-D598-47BB-9DFD-FC9E74C0FE56} = {AB9CA2B8-6F70-431C-8A1D-67479D8A7BE4}
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
EndGlobal
|
EndGlobal
|
||||||
|
|||||||
@@ -42,3 +42,4 @@ using System.Runtime.InteropServices;
|
|||||||
[assembly: AssemblyInformationalVersion("1.0.0.0")]
|
[assembly: AssemblyInformationalVersion("1.0.0.0")]
|
||||||
|
|
||||||
[assembly: InternalsVisibleTo("Microsoft.SqlTools.ServiceLayer.Test")]
|
[assembly: InternalsVisibleTo("Microsoft.SqlTools.ServiceLayer.Test")]
|
||||||
|
[assembly: InternalsVisibleTo("Microsoft.SqlTools.ServiceLayer.IntegrationTests")]
|
||||||
|
|||||||
@@ -18,6 +18,7 @@ dotnet build %WORKINGDIR%..\..\src\Microsoft.SqlTools.ServiceLayer\project.json
|
|||||||
REM run the tests through OpenCover and generate a report
|
REM run the tests through OpenCover and generate a report
|
||||||
dotnet build %WORKINGDIR%..\..\test\Microsoft.SqlTools.ServiceLayer.Test\project.json %DOTNETCONFIG%
|
dotnet build %WORKINGDIR%..\..\test\Microsoft.SqlTools.ServiceLayer.Test\project.json %DOTNETCONFIG%
|
||||||
dotnet build %WORKINGDIR%..\..\test\Microsoft.SqlTools.ServiceLayer.TestDriver\project.json %DOTNETCONFIG%
|
dotnet build %WORKINGDIR%..\..\test\Microsoft.SqlTools.ServiceLayer.TestDriver\project.json %DOTNETCONFIG%
|
||||||
|
dotnet build %WORKINGDIR%..\..\test\Microsoft.SqlTools.ServiceLayer.IntegrationTests\project.json %DOTNETCONFIG%
|
||||||
|
|
||||||
SET TEST_SERVER=localhost
|
SET TEST_SERVER=localhost
|
||||||
SET SQLTOOLSSERVICE_EXE=%WORKINGDIR%..\..\src\Microsoft.SqlTools.ServiceLayer\bin\Integration\netcoreapp1.0\win7-x64\Microsoft.SqlTools.ServiceLayer.exe
|
SET SQLTOOLSSERVICE_EXE=%WORKINGDIR%..\..\src\Microsoft.SqlTools.ServiceLayer\bin\Integration\netcoreapp1.0\win7-x64\Microsoft.SqlTools.ServiceLayer.exe
|
||||||
@@ -33,6 +34,8 @@ SET SERVICECODECOVERAGE=FALSE
|
|||||||
|
|
||||||
"%WORKINGDIR%packages\OpenCover.4.6.519\tools\OpenCover.Console.exe" -mergeoutput -register:user -target:dotnet.exe -targetargs:"test %WORKINGDIR%..\Microsoft.SqlTools.ServiceLayer.Test\project.json %DOTNETCONFIG%" -oldstyle -filter:"+[Microsoft.SqlTools.*]* -[xunit*]*" -output:coverage.xml -searchdirs:%WORKINGDIR%..\Microsoft.SqlTools.ServiceLayer.Test\bin\Debug\netcoreapp1.0
|
"%WORKINGDIR%packages\OpenCover.4.6.519\tools\OpenCover.Console.exe" -mergeoutput -register:user -target:dotnet.exe -targetargs:"test %WORKINGDIR%..\Microsoft.SqlTools.ServiceLayer.Test\project.json %DOTNETCONFIG%" -oldstyle -filter:"+[Microsoft.SqlTools.*]* -[xunit*]*" -output:coverage.xml -searchdirs:%WORKINGDIR%..\Microsoft.SqlTools.ServiceLayer.Test\bin\Debug\netcoreapp1.0
|
||||||
|
|
||||||
|
"%WORKINGDIR%packages\OpenCover.4.6.519\tools\OpenCover.Console.exe" -mergeoutput -register:user -target:dotnet.exe -targetargs:"test %WORKINGDIR%..\Microsoft.SqlTools.ServiceLayer.IntegrationTests\project.json %DOTNETCONFIG%" -oldstyle -filter:"+[Microsoft.SqlTools.*]* -[xunit*]*" -output:coverage.xml -searchdirs:%WORKINGDIR%..\Microsoft.SqlTools.ServiceLayer.IntegrationTests\bin\Debug\netcoreapp1.0
|
||||||
|
|
||||||
"%WORKINGDIR%packages\OpenCoverToCoberturaConverter.0.2.4.0\tools\OpenCoverToCoberturaConverter.exe" -input:coverage.xml -output:outputCobertura.xml -sources:%WORKINGDIR%..\..\src\Microsoft.SqlTools.ServiceLayer
|
"%WORKINGDIR%packages\OpenCoverToCoberturaConverter.0.2.4.0\tools\OpenCoverToCoberturaConverter.exe" -input:coverage.xml -output:outputCobertura.xml -sources:%WORKINGDIR%..\..\src\Microsoft.SqlTools.ServiceLayer
|
||||||
"%WORKINGDIR%packages\ReportGenerator.2.4.5.0\tools\ReportGenerator.exe" "-reports:coverage.xml" "-targetdir:%WORKINGDIR%\reports"
|
"%WORKINGDIR%packages\ReportGenerator.2.4.5.0\tools\ReportGenerator.exe" "-reports:coverage.xml" "-targetdir:%WORKINGDIR%\reports"
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,9 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<configuration>
|
||||||
|
<appSettings>
|
||||||
|
<add key="xunit.methodDisplay" value="method"/>
|
||||||
|
</appSettings>
|
||||||
|
<startup>
|
||||||
|
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.6.1"/>
|
||||||
|
</startup>
|
||||||
|
</configuration>
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
//
|
||||||
|
// Copyright (c) Microsoft. All rights reserved.
|
||||||
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||||
|
//
|
||||||
|
|
||||||
|
using Xunit;
|
||||||
|
|
||||||
|
[assembly: CollectionBehavior(DisableTestParallelization = true)]
|
||||||
@@ -3,8 +3,6 @@
|
|||||||
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||||
//
|
//
|
||||||
|
|
||||||
#if LIVE_CONNECTION_TESTS
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Data;
|
using System.Data;
|
||||||
@@ -24,7 +22,7 @@ using static Microsoft.SqlTools.ServiceLayer.Connection.ReliableConnection.Retry
|
|||||||
using static Microsoft.SqlTools.ServiceLayer.Connection.ReliableConnection.RetryPolicy.TimeBasedRetryPolicy;
|
using static Microsoft.SqlTools.ServiceLayer.Connection.ReliableConnection.RetryPolicy.TimeBasedRetryPolicy;
|
||||||
using static Microsoft.SqlTools.ServiceLayer.Connection.ReliableConnection.SqlSchemaModelErrorCodes;
|
using static Microsoft.SqlTools.ServiceLayer.Connection.ReliableConnection.SqlSchemaModelErrorCodes;
|
||||||
|
|
||||||
namespace Microsoft.SqlTools.ServiceLayer.Test.Connection
|
namespace Microsoft.SqlTools.ServiceLayer.IntegrationTests.Connection
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Tests for the ReliableConnection module.
|
/// Tests for the ReliableConnection module.
|
||||||
@@ -952,5 +950,3 @@ namespace Microsoft.SqlTools.ServiceLayer.Test.Connection
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // LIVE_CONNECTION_TESTS
|
|
||||||
@@ -0,0 +1,139 @@
|
|||||||
|
//
|
||||||
|
// 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.Management.SqlParser.Parser;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.Connection;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.LanguageServices;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.LanguageServices.Completion;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.LanguageServices.Contracts;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.Workspace.Contracts;
|
||||||
|
using Microsoft.SqlTools.Test.Utility;
|
||||||
|
using Xunit;
|
||||||
|
|
||||||
|
namespace Microsoft.SqlTools.ServiceLayer.IntegrationTests.LanguageServer
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Tests for the ServiceHost Language Service tests
|
||||||
|
/// </summary>
|
||||||
|
public class LanguageServiceTests
|
||||||
|
{
|
||||||
|
private static void GetLiveAutoCompleteTestObjects(
|
||||||
|
out TextDocumentPosition textDocument,
|
||||||
|
out ScriptFile scriptFile,
|
||||||
|
out ConnectionInfo connInfo)
|
||||||
|
{
|
||||||
|
textDocument = new TextDocumentPosition
|
||||||
|
{
|
||||||
|
TextDocument = new TextDocumentIdentifier { Uri = TestObjects.ScriptUri },
|
||||||
|
Position = new Position
|
||||||
|
{
|
||||||
|
Line = 0,
|
||||||
|
Character = 0
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
connInfo = TestObjects.InitLiveConnectionInfo(out scriptFile);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test the service initialization code path and verify nothing throws
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void ServiceInitialization()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
TestObjects.InitializeTestServices();
|
||||||
|
}
|
||||||
|
catch (System.ArgumentException)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
Assert.True(LanguageService.Instance.Context != null);
|
||||||
|
Assert.True(LanguageService.ConnectionServiceInstance != null);
|
||||||
|
Assert.True(LanguageService.Instance.CurrentSettings != null);
|
||||||
|
Assert.True(LanguageService.Instance.CurrentWorkspace != null);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test the service initialization code path and verify nothing throws
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void PrepopulateCommonMetadata()
|
||||||
|
{
|
||||||
|
ScriptFile scriptFile;
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfo(out scriptFile);
|
||||||
|
|
||||||
|
ScriptParseInfo scriptInfo = new ScriptParseInfo { IsConnected = true };
|
||||||
|
|
||||||
|
AutoCompleteHelper.PrepopulateCommonMetadata(connInfo, scriptInfo, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
// This test currently requires a live database connection to initialize
|
||||||
|
// SMO connected metadata provider. Since we don't want a live DB dependency
|
||||||
|
// in the CI unit tests this scenario is currently disabled.
|
||||||
|
[Fact]
|
||||||
|
public void AutoCompleteFindCompletions()
|
||||||
|
{
|
||||||
|
TextDocumentPosition textDocument;
|
||||||
|
ConnectionInfo connInfo;
|
||||||
|
ScriptFile scriptFile;
|
||||||
|
GetLiveAutoCompleteTestObjects(out textDocument, out scriptFile, out connInfo);
|
||||||
|
|
||||||
|
textDocument.Position.Character = 7;
|
||||||
|
scriptFile.Contents = "select ";
|
||||||
|
|
||||||
|
var autoCompleteService = LanguageService.Instance;
|
||||||
|
var completions = autoCompleteService.GetCompletionItems(
|
||||||
|
textDocument,
|
||||||
|
scriptFile,
|
||||||
|
connInfo);
|
||||||
|
|
||||||
|
Assert.True(completions.Length > 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Verify that GetSignatureHelp returns not null when the provided TextDocumentPosition
|
||||||
|
/// has an associated ScriptParseInfo and the provided query has a function that should
|
||||||
|
/// provide signature help.
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public async void GetSignatureHelpReturnsNotNullIfParseInfoInitialized()
|
||||||
|
{
|
||||||
|
// When we make a connection to a live database
|
||||||
|
ScriptFile scriptFile;
|
||||||
|
Hosting.ServiceHost.SendEventIgnoreExceptions = true;
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfo(out scriptFile);
|
||||||
|
|
||||||
|
// And we place the cursor after a function that should prompt for signature help
|
||||||
|
string queryWithFunction = "EXEC sys.fn_isrolemember ";
|
||||||
|
scriptFile.Contents = queryWithFunction;
|
||||||
|
TextDocumentPosition textDocument = new TextDocumentPosition
|
||||||
|
{
|
||||||
|
TextDocument = new TextDocumentIdentifier
|
||||||
|
{
|
||||||
|
Uri = scriptFile.ClientFilePath
|
||||||
|
},
|
||||||
|
Position = new Position
|
||||||
|
{
|
||||||
|
Line = 0,
|
||||||
|
Character = queryWithFunction.Length
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// If the SQL has already been parsed
|
||||||
|
var service = LanguageService.Instance;
|
||||||
|
await service.UpdateLanguageServiceOnConnection(connInfo);
|
||||||
|
|
||||||
|
// We should get back a non-null ScriptParseInfo
|
||||||
|
ScriptParseInfo parseInfo = service.GetScriptParseInfo(scriptFile.ClientFilePath);
|
||||||
|
Assert.NotNull(parseInfo);
|
||||||
|
|
||||||
|
// And we should get back a non-null SignatureHelp
|
||||||
|
SignatureHelp signatureHelp = service.GetSignatureHelp(textDocument, scriptFile);
|
||||||
|
Assert.NotNull(signatureHelp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,344 @@
|
|||||||
|
//
|
||||||
|
// Copyright (c) Microsoft. All rights reserved.
|
||||||
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||||
|
//
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Threading;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
|
using Microsoft.SqlServer.Management.Common;
|
||||||
|
using Microsoft.SqlServer.Management.SqlParser.Binder;
|
||||||
|
using Microsoft.SqlServer.Management.SqlParser.Intellisense;
|
||||||
|
using Microsoft.SqlServer.Management.SqlParser.MetadataProvider;
|
||||||
|
using Microsoft.SqlServer.Management.SqlParser.Parser;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.Connection;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.Hosting.Protocol;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.Hosting.Protocol.Contracts;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.LanguageServices;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.LanguageServices.Contracts;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.SqlContext;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.QueryExecution;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.Test.QueryExecution;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.Workspace;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.Workspace.Contracts;
|
||||||
|
using Microsoft.SqlTools.Test.Utility;
|
||||||
|
using Moq;
|
||||||
|
using Xunit;
|
||||||
|
using Location = Microsoft.SqlTools.ServiceLayer.Workspace.Contracts.Location;
|
||||||
|
|
||||||
|
namespace Microsoft.SqlTools.ServiceLayer.IntegrationTests.LanguageServices
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Tests for the language service peek definition/ go to definition feature
|
||||||
|
/// </summary>
|
||||||
|
public class PeekDefinitionTests
|
||||||
|
{
|
||||||
|
private const int TaskTimeout = 30000;
|
||||||
|
|
||||||
|
private readonly string testScriptUri = TestObjects.ScriptUri;
|
||||||
|
|
||||||
|
private readonly string testConnectionKey = "testdbcontextkey";
|
||||||
|
|
||||||
|
private Mock<ConnectedBindingQueue> bindingQueue;
|
||||||
|
|
||||||
|
private Mock<WorkspaceService<SqlToolsSettings>> workspaceService;
|
||||||
|
|
||||||
|
private Mock<RequestContext<Location[]>> requestContext;
|
||||||
|
|
||||||
|
private Mock<IBinder> binder;
|
||||||
|
|
||||||
|
private TextDocumentPosition textDocument;
|
||||||
|
|
||||||
|
private const string OwnerUri = "testFile1";
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test get definition for a table object with active connection
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void GetValidTableDefinitionTest()
|
||||||
|
{
|
||||||
|
// Get live connectionInfo and serverConnection
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
||||||
|
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
||||||
|
|
||||||
|
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
||||||
|
string objectName = "spt_monitor";
|
||||||
|
|
||||||
|
string schemaName = null;
|
||||||
|
string objectType = "TABLE";
|
||||||
|
|
||||||
|
// Get locations for valid table object
|
||||||
|
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetTableScripts, objectName, schemaName, objectType);
|
||||||
|
Assert.NotNull(locations);
|
||||||
|
Cleanup(locations);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test get definition for a invalid table object with active connection
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void GetTableDefinitionInvalidObjectTest()
|
||||||
|
{
|
||||||
|
// Get live connectionInfo and serverConnection
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
||||||
|
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
||||||
|
|
||||||
|
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
||||||
|
string objectName = "test_invalid";
|
||||||
|
string schemaName = null;
|
||||||
|
string objectType = "TABLE";
|
||||||
|
|
||||||
|
// Get locations for invalid table object
|
||||||
|
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetTableScripts, objectName, schemaName, objectType);
|
||||||
|
Assert.Null(locations);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test get definition for a valid table object with schema and active connection
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void GetTableDefinitionWithSchemaTest()
|
||||||
|
{
|
||||||
|
// Get live connectionInfo and serverConnection
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
||||||
|
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
||||||
|
|
||||||
|
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
||||||
|
string objectName = "spt_monitor";
|
||||||
|
|
||||||
|
string schemaName = "dbo";
|
||||||
|
string objectType = "TABLE";
|
||||||
|
|
||||||
|
// Get locations for valid table object with schema name
|
||||||
|
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetTableScripts, objectName, schemaName, objectType);
|
||||||
|
Assert.NotNull(locations);
|
||||||
|
Cleanup(locations);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test GetDefinition with an unsupported type(schema - dbo). Expect a error result.
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void GetUnsupportedDefinitionErrorTest()
|
||||||
|
{
|
||||||
|
ScriptFile scriptFile;
|
||||||
|
TextDocumentPosition textDocument = new TextDocumentPosition
|
||||||
|
{
|
||||||
|
TextDocument = new TextDocumentIdentifier { Uri = OwnerUri },
|
||||||
|
Position = new Position
|
||||||
|
{
|
||||||
|
Line = 0,
|
||||||
|
// test for 'dbo'
|
||||||
|
Character = 16
|
||||||
|
}
|
||||||
|
};
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfo(out scriptFile);
|
||||||
|
scriptFile.Contents = "select * from dbo.func ()";
|
||||||
|
var languageService = new LanguageService();
|
||||||
|
ScriptParseInfo scriptInfo = new ScriptParseInfo { IsConnected = true };
|
||||||
|
languageService.ScriptParseInfoMap.Add(OwnerUri, scriptInfo);
|
||||||
|
|
||||||
|
// When I call the language service
|
||||||
|
var result = languageService.GetDefinition(textDocument, scriptFile, connInfo);
|
||||||
|
|
||||||
|
// Then I expect null locations and an error to be reported
|
||||||
|
Assert.NotNull(result);
|
||||||
|
Assert.True(result.IsErrorResult);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Get Definition for a object with no definition. Expect a error result
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void GetDefinitionWithNoResultsFoundError()
|
||||||
|
{
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
||||||
|
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
||||||
|
|
||||||
|
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
||||||
|
string objectName = "from";
|
||||||
|
|
||||||
|
List<Declaration> declarations = new List<Declaration>();
|
||||||
|
DefinitionResult result = peekDefinition.GetScript(declarations, objectName, null);
|
||||||
|
|
||||||
|
Assert.NotNull(result);
|
||||||
|
Assert.True(result.IsErrorResult);
|
||||||
|
Assert.Equal(SR.PeekDefinitionNoResultsError, result.Message);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test GetDefinition with a forced timeout. Expect a error result.
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void GetDefinitionTimeoutTest()
|
||||||
|
{
|
||||||
|
// Given a binding queue that will automatically time out
|
||||||
|
var languageService = new LanguageService();
|
||||||
|
Mock<ConnectedBindingQueue> queueMock = new Mock<ConnectedBindingQueue>();
|
||||||
|
languageService.BindingQueue = queueMock.Object;
|
||||||
|
ManualResetEvent mre = new ManualResetEvent(true); // Do not block
|
||||||
|
Mock<QueueItem> itemMock = new Mock<QueueItem>();
|
||||||
|
itemMock.Setup(i => i.ItemProcessed).Returns(mre);
|
||||||
|
|
||||||
|
DefinitionResult timeoutResult = null;
|
||||||
|
|
||||||
|
queueMock.Setup(q => q.QueueBindingOperation(
|
||||||
|
It.IsAny<string>(),
|
||||||
|
It.IsAny<Func<IBindingContext, CancellationToken, object>>(),
|
||||||
|
It.IsAny<Func<IBindingContext, object>>(),
|
||||||
|
It.IsAny<int?>(),
|
||||||
|
It.IsAny<int?>()))
|
||||||
|
.Callback<string, Func<IBindingContext, CancellationToken, object>, Func<IBindingContext, object>, int?, int?>(
|
||||||
|
(key, bindOperation, timeoutOperation, blah, blah2) =>
|
||||||
|
{
|
||||||
|
timeoutResult = (DefinitionResult) timeoutOperation((IBindingContext)null);
|
||||||
|
itemMock.Object.Result = timeoutResult;
|
||||||
|
})
|
||||||
|
.Returns(() => itemMock.Object);
|
||||||
|
|
||||||
|
ScriptFile scriptFile;
|
||||||
|
TextDocumentPosition textDocument = new TextDocumentPosition
|
||||||
|
{
|
||||||
|
TextDocument = new TextDocumentIdentifier { Uri = OwnerUri },
|
||||||
|
Position = new Position
|
||||||
|
{
|
||||||
|
Line = 0,
|
||||||
|
Character = 20
|
||||||
|
}
|
||||||
|
};
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfo(out scriptFile);
|
||||||
|
scriptFile.Contents = "select * from dbo.func ()";
|
||||||
|
|
||||||
|
ScriptParseInfo scriptInfo = new ScriptParseInfo { IsConnected = true };
|
||||||
|
languageService.ScriptParseInfoMap.Add(OwnerUri, scriptInfo);
|
||||||
|
|
||||||
|
// When I call the language service
|
||||||
|
var result = languageService.GetDefinition(textDocument, scriptFile, connInfo);
|
||||||
|
|
||||||
|
// Then I expect null locations and an error to be reported
|
||||||
|
Assert.NotNull(result);
|
||||||
|
Assert.True(result.IsErrorResult);
|
||||||
|
// Check timeout message
|
||||||
|
Assert.Equal(SR.PeekDefinitionTimedoutError, result.Message);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test get definition for a view object with active connection
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void GetValidViewDefinitionTest()
|
||||||
|
{
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
||||||
|
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
||||||
|
|
||||||
|
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
||||||
|
string objectName = "objects";
|
||||||
|
string schemaName = "sys";
|
||||||
|
string objectType = "VIEW";
|
||||||
|
|
||||||
|
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetViewScripts, objectName, schemaName, objectType);
|
||||||
|
Assert.NotNull(locations);
|
||||||
|
Cleanup(locations);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test get definition for an invalid view object with no schema name and with active connection
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void GetViewDefinitionInvalidObjectTest()
|
||||||
|
{
|
||||||
|
// Get live connectionInfo and serverConnection
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
||||||
|
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
||||||
|
|
||||||
|
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
||||||
|
string objectName = "objects";
|
||||||
|
string schemaName = null;
|
||||||
|
string objectType = "VIEW";
|
||||||
|
|
||||||
|
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetViewScripts, objectName, schemaName, objectType);
|
||||||
|
Assert.Null(locations);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test get definition for a stored procedure object with active connection
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void GetStoredProcedureDefinitionTest()
|
||||||
|
{
|
||||||
|
// Get live connectionInfo and serverConnection
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
||||||
|
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
||||||
|
|
||||||
|
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
||||||
|
string objectName = "sp_MSrepl_startup";
|
||||||
|
|
||||||
|
string schemaName = "dbo";
|
||||||
|
string objectType = "PROCEDURE";
|
||||||
|
|
||||||
|
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetStoredProcedureScripts, objectName, schemaName, objectType);
|
||||||
|
Assert.NotNull(locations);
|
||||||
|
Cleanup(locations);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test get definition for a stored procedure object that does not exist with active connection
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void GetStoredProcedureDefinitionFailureTest()
|
||||||
|
{
|
||||||
|
// Get live connectionInfo and serverConnection
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
||||||
|
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
||||||
|
|
||||||
|
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
||||||
|
string objectName = "SP2";
|
||||||
|
string schemaName = "dbo";
|
||||||
|
string objectType = "PROCEDURE";
|
||||||
|
|
||||||
|
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetStoredProcedureScripts, objectName, schemaName, objectType);
|
||||||
|
Assert.Null(locations);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Test get definition for a stored procedure object with active connection and no schema
|
||||||
|
/// </summary>
|
||||||
|
[Fact]
|
||||||
|
public void GetStoredProcedureDefinitionWithoutSchemaTest()
|
||||||
|
{
|
||||||
|
// Get live connectionInfo and serverConnection
|
||||||
|
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
||||||
|
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
||||||
|
|
||||||
|
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
||||||
|
string objectName = "sp_MSrepl_startup";
|
||||||
|
string schemaName = null;
|
||||||
|
string objectType = "PROCEDURE";
|
||||||
|
|
||||||
|
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetStoredProcedureScripts, objectName, schemaName, objectType);
|
||||||
|
Assert.NotNull(locations);
|
||||||
|
Cleanup(locations);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Helper method to clean up script files
|
||||||
|
/// </summary>
|
||||||
|
private void Cleanup(Location[] locations)
|
||||||
|
{
|
||||||
|
Uri fileUri = new Uri(locations[0].Uri);
|
||||||
|
if (File.Exists(fileUri.LocalPath))
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File.Delete(fileUri.LocalPath);
|
||||||
|
}
|
||||||
|
catch(Exception)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,22 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<Project ToolsVersion="14.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
|
<PropertyGroup>
|
||||||
|
<VisualStudioVersion Condition="'$(VisualStudioVersion)' == ''">14.0</VisualStudioVersion>
|
||||||
|
<VSToolsPath Condition="'$(VSToolsPath)' == ''">$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)</VSToolsPath>
|
||||||
|
</PropertyGroup>
|
||||||
|
<Import Project="$(VSToolsPath)\DotNet\Microsoft.DotNet.Props" Condition="'$(VSToolsPath)' != ''" />
|
||||||
|
<PropertyGroup Label="Globals">
|
||||||
|
<ProjectGuid>08af0209-d598-47bb-9dfd-fc9e74c0fe56</ProjectGuid>
|
||||||
|
<RootNamespace>Microsoft.SqlTools.ServiceLayer.IntegrationTests</RootNamespace>
|
||||||
|
<BaseIntermediateOutputPath Condition="'$(BaseIntermediateOutputPath)'==''">.\obj</BaseIntermediateOutputPath>
|
||||||
|
<OutputPath Condition="'$(OutputPath)'=='' ">.\bin\</OutputPath>
|
||||||
|
<TargetFrameworkVersion>v4.5.2</TargetFrameworkVersion>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup>
|
||||||
|
<SchemaVersion>2.0</SchemaVersion>
|
||||||
|
</PropertyGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Service Include="{82a7f48d-3b50-4b1e-b82e-3ada8210c358}" />
|
||||||
|
</ItemGroup>
|
||||||
|
<Import Project="$(VSToolsPath)\DotNet\Microsoft.DotNet.targets" Condition="'$(VSToolsPath)' != ''" />
|
||||||
|
</Project>
|
||||||
@@ -0,0 +1,41 @@
|
|||||||
|
//
|
||||||
|
// Copyright (c) Microsoft. All rights reserved.
|
||||||
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||||
|
//
|
||||||
|
|
||||||
|
using System.Reflection;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
|
|
||||||
|
// General Information about an assembly is controlled through the following
|
||||||
|
// set of attributes. Change these attribute values to modify the information
|
||||||
|
// associated with an assembly.
|
||||||
|
[assembly: AssemblyTitle("SqlToolsEditorServices.Test.Transport.Stdio")]
|
||||||
|
[assembly: AssemblyDescription("")]
|
||||||
|
[assembly: AssemblyConfiguration("")]
|
||||||
|
[assembly: AssemblyCompany("")]
|
||||||
|
[assembly: AssemblyProduct("SqlToolsEditorServices.Test.Transport.Stdio")]
|
||||||
|
[assembly: AssemblyCopyright("Copyright <20> 2015")]
|
||||||
|
[assembly: AssemblyTrademark("")]
|
||||||
|
[assembly: AssemblyCulture("")]
|
||||||
|
|
||||||
|
// Setting ComVisible to false makes the types in this assembly not visible
|
||||||
|
// to COM components. If you need to access a type in this assembly from
|
||||||
|
// COM, set the ComVisible attribute to true on that type.
|
||||||
|
[assembly: ComVisible(false)]
|
||||||
|
|
||||||
|
// The following GUID is for the ID of the typelib if this project is exposed to COM
|
||||||
|
[assembly: Guid("07137FCA-76D0-4CE7-9764-C21DB7A57093")]
|
||||||
|
|
||||||
|
// Version information for an assembly consists of the following four values:
|
||||||
|
//
|
||||||
|
// Major Version
|
||||||
|
// Minor Version
|
||||||
|
// Build Number
|
||||||
|
// Revision
|
||||||
|
//
|
||||||
|
// You can specify all the values or you can default the Build and Revision Numbers
|
||||||
|
// by using the '*' as shown below:
|
||||||
|
// [assembly: AssemblyVersion("1.0.*")]
|
||||||
|
[assembly: AssemblyVersion("1.0.0.0")]
|
||||||
|
[assembly: AssemblyFileVersion("1.0.0.0")]
|
||||||
|
|
||||||
@@ -3,8 +3,6 @@
|
|||||||
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||||
//
|
//
|
||||||
|
|
||||||
#if LIVE_CONNECTION_TESTS
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Data.Common;
|
using System.Data.Common;
|
||||||
using Microsoft.SqlTools.ServiceLayer.Connection;
|
using Microsoft.SqlTools.ServiceLayer.Connection;
|
||||||
@@ -13,7 +11,7 @@ using Microsoft.SqlTools.ServiceLayer.Workspace.Contracts;
|
|||||||
using Microsoft.SqlTools.Test.Utility;
|
using Microsoft.SqlTools.Test.Utility;
|
||||||
using Xunit;
|
using Xunit;
|
||||||
|
|
||||||
namespace Microsoft.SqlTools.ServiceLayer.Test.QueryExecution.DataStorage
|
namespace Microsoft.SqlTools.ServiceLayer.IntegrationTests.QueryExecution.DataStorage
|
||||||
{
|
{
|
||||||
public class StorageDataReaderTests
|
public class StorageDataReaderTests
|
||||||
{
|
{
|
||||||
@@ -106,5 +104,3 @@ namespace Microsoft.SqlTools.ServiceLayer.Test.QueryExecution.DataStorage
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
|
||||||
@@ -0,0 +1,11 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<packages>
|
||||||
|
<package id="Newtonsoft.Json" version="8.0.2" targetFramework="net461" />
|
||||||
|
<package id="xunit" version="2.1.0" targetFramework="net45" />
|
||||||
|
<package id="xunit.abstractions" version="2.0.0" targetFramework="net45" />
|
||||||
|
<package id="xunit.assert" version="2.1.0" targetFramework="net45" />
|
||||||
|
<package id="xunit.core" version="2.1.0" targetFramework="net45" />
|
||||||
|
<package id="xunit.extensibility.core" version="2.1.0" targetFramework="net45" />
|
||||||
|
<package id="xunit.extensibility.execution" version="2.1.0" targetFramework="net45" />
|
||||||
|
<package id="xunit.runner.visualstudio" version="2.1.0" targetFramework="net45" />
|
||||||
|
</packages>
|
||||||
@@ -0,0 +1,47 @@
|
|||||||
|
{
|
||||||
|
"name": "Microsoft.SqlTools.ServiceLayer.IntegrationTests",
|
||||||
|
"version": "1.0.0-*",
|
||||||
|
"buildOptions": {
|
||||||
|
"debugType": "portable"
|
||||||
|
},
|
||||||
|
"configurations": {
|
||||||
|
"Integration": {
|
||||||
|
"buildOptions": {
|
||||||
|
"define": [
|
||||||
|
"WINDOWS_ONLY_BUILD" ]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"Newtonsoft.Json": "9.0.1",
|
||||||
|
"System.Runtime.Serialization.Primitives": "4.1.1",
|
||||||
|
"System.Data.Common": "4.1.0",
|
||||||
|
"System.Data.SqlClient": "4.4.0-sqltools-24613-04",
|
||||||
|
"Microsoft.SqlServer.Smo": "140.1.12",
|
||||||
|
"System.Security.SecureString": "4.0.0",
|
||||||
|
"System.Collections.Specialized": "4.0.1",
|
||||||
|
"System.ComponentModel.TypeConverter": "4.1.0",
|
||||||
|
"xunit": "2.1.0",
|
||||||
|
"dotnet-test-xunit": "1.0.0-rc2-192208-24",
|
||||||
|
"Microsoft.SqlTools.ServiceLayer": {
|
||||||
|
"target": "project"
|
||||||
|
},
|
||||||
|
"Moq": "4.6.36-alpha",
|
||||||
|
"Microsoft.SqlTools.ServiceLayer.Test": "1.0.0-*"
|
||||||
|
},
|
||||||
|
"testRunner": "xunit",
|
||||||
|
"frameworks": {
|
||||||
|
"netcoreapp1.0": {
|
||||||
|
"dependencies": {
|
||||||
|
"Microsoft.NETCore.App": {
|
||||||
|
"type": "platform",
|
||||||
|
"version": "1.0.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"imports": [
|
||||||
|
"dotnet5.4",
|
||||||
|
"portable-net451+win8"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -18,9 +18,6 @@ namespace Microsoft.SqlTools.ServiceLayer.Test.LanguageServer
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public class LanguageServiceTests
|
public class LanguageServiceTests
|
||||||
{
|
{
|
||||||
#region "Diagnostics tests"
|
|
||||||
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Verify that the latest SqlParser (2016 as of this writing) is used by default
|
/// Verify that the latest SqlParser (2016 as of this writing) is used by default
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -197,134 +194,5 @@ namespace Microsoft.SqlTools.ServiceLayer.Test.LanguageServer
|
|||||||
AutoCompleteHelper.GetDefaultCompletionItems(scriptDocumentInfo, false);
|
AutoCompleteHelper.GetDefaultCompletionItems(scriptDocumentInfo, false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region "General Language Service tests"
|
|
||||||
|
|
||||||
#if LIVE_CONNECTION_TESTS
|
|
||||||
|
|
||||||
private static void GetLiveAutoCompleteTestObjects(
|
|
||||||
out TextDocumentPosition textDocument,
|
|
||||||
out ScriptFile scriptFile,
|
|
||||||
out ConnectionInfo connInfo)
|
|
||||||
{
|
|
||||||
textDocument = new TextDocumentPosition
|
|
||||||
{
|
|
||||||
TextDocument = new TextDocumentIdentifier {Uri = TestObjects.ScriptUri},
|
|
||||||
Position = new Position
|
|
||||||
{
|
|
||||||
Line = 0,
|
|
||||||
Character = 0
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
connInfo = TestObjects.InitLiveConnectionInfo(out scriptFile);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Test the service initialization code path and verify nothing throws
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void ServiceInitialization()
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
TestObjects.InitializeTestServices();
|
|
||||||
}
|
|
||||||
catch (System.ArgumentException)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
Assert.True(LanguageService.Instance.Context != null);
|
|
||||||
Assert.True(LanguageService.ConnectionServiceInstance != null);
|
|
||||||
Assert.True(LanguageService.Instance.CurrentSettings != null);
|
|
||||||
Assert.True(LanguageService.Instance.CurrentWorkspace != null);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Test the service initialization code path and verify nothing throws
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void PrepopulateCommonMetadata()
|
|
||||||
{
|
|
||||||
ScriptFile scriptFile;
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfo(out scriptFile);
|
|
||||||
|
|
||||||
ScriptParseInfo scriptInfo = new ScriptParseInfo {IsConnected = true};
|
|
||||||
|
|
||||||
AutoCompleteHelper.PrepopulateCommonMetadata(connInfo, scriptInfo, null);
|
|
||||||
}
|
|
||||||
|
|
||||||
// This test currently requires a live database connection to initialize
|
|
||||||
// SMO connected metadata provider. Since we don't want a live DB dependency
|
|
||||||
// in the CI unit tests this scenario is currently disabled.
|
|
||||||
[Fact]
|
|
||||||
public void AutoCompleteFindCompletions()
|
|
||||||
{
|
|
||||||
TextDocumentPosition textDocument;
|
|
||||||
ConnectionInfo connInfo;
|
|
||||||
ScriptFile scriptFile;
|
|
||||||
GetLiveAutoCompleteTestObjects(out textDocument, out scriptFile, out connInfo);
|
|
||||||
|
|
||||||
textDocument.Position.Character = 7;
|
|
||||||
scriptFile.Contents = "select ";
|
|
||||||
|
|
||||||
var autoCompleteService = LanguageService.Instance;
|
|
||||||
var completions = autoCompleteService.GetCompletionItems(
|
|
||||||
textDocument,
|
|
||||||
scriptFile,
|
|
||||||
connInfo);
|
|
||||||
|
|
||||||
Assert.True(completions.Length > 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Verify that GetSignatureHelp returns not null when the provided TextDocumentPosition
|
|
||||||
/// has an associated ScriptParseInfo and the provided query has a function that should
|
|
||||||
/// provide signature help.
|
|
||||||
/// </summary>
|
|
||||||
|
|
||||||
// turn-off broken test until it can be fixed
|
|
||||||
//[Fact]
|
|
||||||
public async void GetSignatureHelpReturnsNotNullIfParseInfoInitialized()
|
|
||||||
{
|
|
||||||
// When we make a connection to a live database
|
|
||||||
ScriptFile scriptFile;
|
|
||||||
Hosting.ServiceHost.SendEventIgnoreExceptions = true;
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfo(out scriptFile);
|
|
||||||
|
|
||||||
// And we place the cursor after a function that should prompt for signature help
|
|
||||||
string queryWithFunction = "EXEC sys.fn_isrolemember ";
|
|
||||||
scriptFile.Contents = queryWithFunction;
|
|
||||||
TextDocumentPosition textDocument = new TextDocumentPosition
|
|
||||||
{
|
|
||||||
TextDocument = new TextDocumentIdentifier
|
|
||||||
{
|
|
||||||
Uri = scriptFile.ClientFilePath
|
|
||||||
},
|
|
||||||
Position = new Position
|
|
||||||
{
|
|
||||||
Line = 0,
|
|
||||||
Character = queryWithFunction.Length
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// If the SQL has already been parsed
|
|
||||||
var service = LanguageService.Instance;
|
|
||||||
await service.UpdateLanguageServiceOnConnection(connInfo);
|
|
||||||
|
|
||||||
// We should get back a non-null ScriptParseInfo
|
|
||||||
ScriptParseInfo parseInfo = service.GetScriptParseInfo(scriptFile.ClientFilePath);
|
|
||||||
Assert.NotNull(parseInfo);
|
|
||||||
|
|
||||||
// And we should get back a non-null SignatureHelp
|
|
||||||
SignatureHelp signatureHelp = service.GetSignatureHelp(textDocument, scriptFile);
|
|
||||||
Assert.NotNull(signatureHelp);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -221,295 +221,5 @@ namespace Microsoft.SqlTools.ServiceLayer.Test.LanguageServices
|
|||||||
// Expected not to throw any exception
|
// Expected not to throw any exception
|
||||||
languageService.DeletePeekDefinitionScripts();
|
languageService.DeletePeekDefinitionScripts();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if LIVE_CONNECTION_TESTS
|
|
||||||
/// <summary>
|
|
||||||
/// Test get definition for a table object with active connection
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void GetValidTableDefinitionTest()
|
|
||||||
{
|
|
||||||
// Get live connectionInfo and serverConnection
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
|
||||||
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
|
||||||
|
|
||||||
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
|
||||||
string objectName = "spt_monitor";
|
|
||||||
|
|
||||||
string schemaName = null;
|
|
||||||
string objectType = "TABLE";
|
|
||||||
|
|
||||||
// Get locations for valid table object
|
|
||||||
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetTableScripts, objectName, schemaName, objectType);
|
|
||||||
Assert.NotNull(locations);
|
|
||||||
Cleanup(locations);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Test get definition for a invalid table object with active connection
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void GetTableDefinitionInvalidObjectTest()
|
|
||||||
{
|
|
||||||
// Get live connectionInfo and serverConnection
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
|
||||||
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
|
||||||
|
|
||||||
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
|
||||||
string objectName = "test_invalid";
|
|
||||||
string schemaName = null;
|
|
||||||
string objectType = "TABLE";
|
|
||||||
|
|
||||||
// Get locations for invalid table object
|
|
||||||
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetTableScripts, objectName, schemaName, objectType);
|
|
||||||
Assert.Null(locations);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Test get definition for a valid table object with schema and active connection
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void GetTableDefinitionWithSchemaTest()
|
|
||||||
{
|
|
||||||
// Get live connectionInfo and serverConnection
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
|
||||||
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
|
||||||
|
|
||||||
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
|
||||||
string objectName = "spt_monitor";
|
|
||||||
|
|
||||||
string schemaName = "dbo";
|
|
||||||
string objectType = "TABLE";
|
|
||||||
|
|
||||||
// Get locations for valid table object with schema name
|
|
||||||
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetTableScripts, objectName, schemaName, objectType);
|
|
||||||
Assert.NotNull(locations);
|
|
||||||
Cleanup(locations);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Test GetDefinition with an unsupported type(schema - dbo). Expect a error result.
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void GetUnsupportedDefinitionErrorTest()
|
|
||||||
{
|
|
||||||
ScriptFile scriptFile;
|
|
||||||
TextDocumentPosition textDocument = new TextDocumentPosition
|
|
||||||
{
|
|
||||||
TextDocument = new TextDocumentIdentifier { Uri = OwnerUri },
|
|
||||||
Position = new Position
|
|
||||||
{
|
|
||||||
Line = 0,
|
|
||||||
// test for 'dbo'
|
|
||||||
Character = 16
|
|
||||||
}
|
|
||||||
};
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfo(out scriptFile);
|
|
||||||
scriptFile.Contents = "select * from dbo.func ()";
|
|
||||||
var languageService = new LanguageService();
|
|
||||||
ScriptParseInfo scriptInfo = new ScriptParseInfo { IsConnected = true };
|
|
||||||
languageService.ScriptParseInfoMap.Add(OwnerUri, scriptInfo);
|
|
||||||
|
|
||||||
// When I call the language service
|
|
||||||
var result = languageService.GetDefinition(textDocument, scriptFile, connInfo);
|
|
||||||
|
|
||||||
// Then I expect null locations and an error to be reported
|
|
||||||
Assert.NotNull(result);
|
|
||||||
Assert.True(result.IsErrorResult);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Get Definition for a object with no definition. Expect a error result
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void GetDefinitionWithNoResultsFoundError()
|
|
||||||
{
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
|
||||||
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
|
||||||
|
|
||||||
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
|
||||||
string objectName = "from";
|
|
||||||
|
|
||||||
List<Declaration> declarations = new List<Declaration>();
|
|
||||||
DefinitionResult result = peekDefinition.GetScript(declarations, objectName, null);
|
|
||||||
|
|
||||||
Assert.NotNull(result);
|
|
||||||
Assert.True(result.IsErrorResult);
|
|
||||||
Assert.Equal(SR.PeekDefinitionNoResultsError, result.Message);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Test GetDefinition with a forced timeout. Expect a error result.
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void GetDefinitionTimeoutTest()
|
|
||||||
{
|
|
||||||
// Given a binding queue that will automatically time out
|
|
||||||
var languageService = new LanguageService();
|
|
||||||
Mock<ConnectedBindingQueue> queueMock = new Mock<ConnectedBindingQueue>();
|
|
||||||
languageService.BindingQueue = queueMock.Object;
|
|
||||||
ManualResetEvent mre = new ManualResetEvent(true); // Do not block
|
|
||||||
Mock<QueueItem> itemMock = new Mock<QueueItem>();
|
|
||||||
itemMock.Setup(i => i.ItemProcessed).Returns(mre);
|
|
||||||
|
|
||||||
DefinitionResult timeoutResult = null;
|
|
||||||
|
|
||||||
queueMock.Setup(q => q.QueueBindingOperation(
|
|
||||||
It.IsAny<string>(),
|
|
||||||
It.IsAny<Func<IBindingContext, CancellationToken, object>>(),
|
|
||||||
It.IsAny<Func<IBindingContext, object>>(),
|
|
||||||
It.IsAny<int?>(),
|
|
||||||
It.IsAny<int?>()))
|
|
||||||
.Callback<string, Func<IBindingContext, CancellationToken, object>, Func<IBindingContext, object>, int?, int?>(
|
|
||||||
(key, bindOperation, timeoutOperation, blah, blah2) =>
|
|
||||||
{
|
|
||||||
timeoutResult = (DefinitionResult) timeoutOperation((IBindingContext)null);
|
|
||||||
itemMock.Object.Result = timeoutResult;
|
|
||||||
})
|
|
||||||
.Returns(() => itemMock.Object);
|
|
||||||
|
|
||||||
ScriptFile scriptFile;
|
|
||||||
TextDocumentPosition textDocument = new TextDocumentPosition
|
|
||||||
{
|
|
||||||
TextDocument = new TextDocumentIdentifier { Uri = OwnerUri },
|
|
||||||
Position = new Position
|
|
||||||
{
|
|
||||||
Line = 0,
|
|
||||||
Character = 20
|
|
||||||
}
|
|
||||||
};
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfo(out scriptFile);
|
|
||||||
scriptFile.Contents = "select * from dbo.func ()";
|
|
||||||
|
|
||||||
ScriptParseInfo scriptInfo = new ScriptParseInfo { IsConnected = true };
|
|
||||||
languageService.ScriptParseInfoMap.Add(OwnerUri, scriptInfo);
|
|
||||||
|
|
||||||
// When I call the language service
|
|
||||||
var result = languageService.GetDefinition(textDocument, scriptFile, connInfo);
|
|
||||||
|
|
||||||
// Then I expect null locations and an error to be reported
|
|
||||||
Assert.NotNull(result);
|
|
||||||
Assert.True(result.IsErrorResult);
|
|
||||||
// Check timeout message
|
|
||||||
Assert.Equal(SR.PeekDefinitionTimedoutError, result.Message);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Test get definition for a view object with active connection
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void GetValidViewDefinitionTest()
|
|
||||||
{
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
|
||||||
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
|
||||||
|
|
||||||
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
|
||||||
string objectName = "objects";
|
|
||||||
string schemaName = "sys";
|
|
||||||
string objectType = "VIEW";
|
|
||||||
|
|
||||||
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetViewScripts, objectName, schemaName, objectType);
|
|
||||||
Assert.NotNull(locations);
|
|
||||||
Cleanup(locations);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Test get definition for an invalid view object with no schema name and with active connection
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void GetViewDefinitionInvalidObjectTest()
|
|
||||||
{
|
|
||||||
// Get live connectionInfo and serverConnection
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
|
||||||
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
|
||||||
|
|
||||||
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
|
||||||
string objectName = "objects";
|
|
||||||
string schemaName = null;
|
|
||||||
string objectType = "VIEW";
|
|
||||||
|
|
||||||
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetViewScripts, objectName, schemaName, objectType);
|
|
||||||
Assert.Null(locations);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Test get definition for a stored procedure object with active connection
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void GetStoredProcedureDefinitionTest()
|
|
||||||
{
|
|
||||||
// Get live connectionInfo and serverConnection
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
|
||||||
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
|
||||||
|
|
||||||
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
|
||||||
string objectName = "sp_MSrepl_startup";
|
|
||||||
|
|
||||||
string schemaName = "dbo";
|
|
||||||
string objectType = "PROCEDURE";
|
|
||||||
|
|
||||||
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetStoredProcedureScripts, objectName, schemaName, objectType);
|
|
||||||
Assert.NotNull(locations);
|
|
||||||
Cleanup(locations);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Test get definition for a stored procedure object that does not exist with active connection
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void GetStoredProcedureDefinitionFailureTest()
|
|
||||||
{
|
|
||||||
// Get live connectionInfo and serverConnection
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
|
||||||
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
|
||||||
|
|
||||||
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
|
||||||
string objectName = "SP2";
|
|
||||||
string schemaName = "dbo";
|
|
||||||
string objectType = "PROCEDURE";
|
|
||||||
|
|
||||||
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetStoredProcedureScripts, objectName, schemaName, objectType);
|
|
||||||
Assert.Null(locations);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Test get definition for a stored procedure object with active connection and no schema
|
|
||||||
/// </summary>
|
|
||||||
[Fact]
|
|
||||||
public void GetStoredProcedureDefinitionWithoutSchemaTest()
|
|
||||||
{
|
|
||||||
// Get live connectionInfo and serverConnection
|
|
||||||
ConnectionInfo connInfo = TestObjects.InitLiveConnectionInfoForDefinition();
|
|
||||||
ServerConnection serverConnection = TestObjects.InitLiveServerConnectionForDefinition(connInfo);
|
|
||||||
|
|
||||||
PeekDefinition peekDefinition = new PeekDefinition(serverConnection, connInfo);
|
|
||||||
string objectName = "sp_MSrepl_startup";
|
|
||||||
string schemaName = null;
|
|
||||||
string objectType = "PROCEDURE";
|
|
||||||
|
|
||||||
Location[] locations = peekDefinition.GetSqlObjectDefinition(peekDefinition.GetStoredProcedureScripts, objectName, schemaName, objectType);
|
|
||||||
Assert.NotNull(locations);
|
|
||||||
Cleanup(locations);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Helper method to clean up script files
|
|
||||||
/// </summary>
|
|
||||||
private void Cleanup(Location[] locations)
|
|
||||||
{
|
|
||||||
Uri fileUri = new Uri(locations[0].Uri);
|
|
||||||
if (File.Exists(fileUri.LocalPath))
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
File.Delete(fileUri.LocalPath);
|
|
||||||
}
|
|
||||||
catch(Exception)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,7 +8,6 @@
|
|||||||
"Integration": {
|
"Integration": {
|
||||||
"buildOptions": {
|
"buildOptions": {
|
||||||
"define": [
|
"define": [
|
||||||
"LIVE_CONNECTION_TESTS",
|
|
||||||
"WINDOWS_ONLY_BUILD"
|
"WINDOWS_ONLY_BUILD"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user