mirror of
https://github.com/ckaczor/sqltoolsservice.git
synced 2026-01-14 09:59:48 -05:00
The goal of this make sure that test code is correctly organized to ensure that test suites aren't dependent on each other.
* UnitTests get their own project now (renaming Microsoft.SqlTools.ServiceLayer.Test to Microsoft.SqlTools.ServiceLayer.UnitTests) which is about 90% of the changes to the files.
* IntegrationTests no longer depends on UnitTests, only Test.Common
* Any shared components from TestObjects that spins up a "live" connection has been moved to IntegrationTests Utility/LiveConnectionHelper.cs
* The dictionary-based mock file stream factory has been moved to Test.Common since it is used by UnitTests and IntegrationTests
* Added a overload that doesn't take a dictionary for when we don't care about monitoring the storage (about 90% of the time)
* The RunIf* wrapper methods have been moved to Test.Common
* OwnerUri and StandardQuery constants have been moved to Test.Common Constants file
* Updating to latest SDK version available at https://www.microsoft.com/net/core#windowscmd
* Moving unit tests to unit test folder
* Changing namespaces to UnitTests
* Moving some constants and shared functionality into common project, making the UnitTests reference it
* Unit tests are working!
* Integration tests are working
* Updating automated test runs
* Fixing one last broken unit test
* Exposing internals for other projects
* Moving edit data tests to UnitTest project
* Applying refactor fixes to unit tests
* Fixing flaky test that wasn't awaiting completion
94 lines
4.4 KiB
C#
94 lines
4.4 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 System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Threading;
|
|
using Microsoft.SqlServer.Management.SqlParser.Intellisense;
|
|
using Microsoft.SqlServer.Management.SqlParser.MetadataProvider;
|
|
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 Moq;
|
|
using Xunit;
|
|
|
|
namespace Microsoft.SqlTools.ServiceLayer.UnitTests.LanguageServer
|
|
{
|
|
public class CompletionServiceTest
|
|
{
|
|
[Fact]
|
|
public void CompletionItemsShouldCreatedUsingSqlParserIfTheProcessDoesNotTimeout()
|
|
{
|
|
ConnectedBindingQueue bindingQueue = new ConnectedBindingQueue();
|
|
ScriptDocumentInfo docInfo = CreateScriptDocumentInfo();
|
|
CompletionService completionService = new CompletionService(bindingQueue);
|
|
ConnectionInfo connectionInfo = new ConnectionInfo(null, null, null);
|
|
bool useLowerCaseSuggestions = true;
|
|
CompletionItem[] defaultCompletionList = AutoCompleteHelper.GetDefaultCompletionItems(docInfo, useLowerCaseSuggestions);
|
|
|
|
List<Declaration> declarations = new List<Declaration>();
|
|
|
|
var sqlParserWrapper = new Mock<ISqlParserWrapper>();
|
|
sqlParserWrapper.Setup(x => x.FindCompletions(docInfo.ScriptParseInfo.ParseResult, docInfo.ParserLine, docInfo.ParserColumn,
|
|
It.IsAny<IMetadataDisplayInfoProvider>())).Returns(declarations);
|
|
completionService.SqlParserWrapper = sqlParserWrapper.Object;
|
|
|
|
AutoCompletionResult result = completionService.CreateCompletions(connectionInfo, docInfo, useLowerCaseSuggestions);
|
|
Assert.NotNull(result);
|
|
Assert.NotEqual(result.CompletionItems == null ? 0 : result.CompletionItems.Count(), defaultCompletionList.Count());
|
|
}
|
|
|
|
[Fact]
|
|
public void CompletionItemsShouldCreatedUsingDefaultListIfTheSqlParserProcessTimesout()
|
|
{
|
|
ConnectedBindingQueue bindingQueue = new ConnectedBindingQueue();
|
|
ScriptDocumentInfo docInfo = CreateScriptDocumentInfo();
|
|
CompletionService completionService = new CompletionService(bindingQueue);
|
|
ConnectionInfo connectionInfo = new ConnectionInfo(null, null, null);
|
|
bool useLowerCaseSuggestions = true;
|
|
List<Declaration> declarations = new List<Declaration>();
|
|
CompletionItem[] defaultCompletionList = AutoCompleteHelper.GetDefaultCompletionItems(docInfo, useLowerCaseSuggestions);
|
|
|
|
var sqlParserWrapper = new Mock<ISqlParserWrapper>();
|
|
sqlParserWrapper.Setup(x => x.FindCompletions(docInfo.ScriptParseInfo.ParseResult, docInfo.ParserLine, docInfo.ParserColumn,
|
|
It.IsAny<IMetadataDisplayInfoProvider>())).Callback(() => Thread.Sleep(LanguageService.BindingTimeout + 100)).Returns(declarations);
|
|
completionService.SqlParserWrapper = sqlParserWrapper.Object;
|
|
|
|
AutoCompletionResult result = completionService.CreateCompletions(connectionInfo, docInfo, useLowerCaseSuggestions);
|
|
Assert.NotNull(result);
|
|
Assert.Equal(result.CompletionItems.Count(), defaultCompletionList.Count());
|
|
Thread.Sleep(3000);
|
|
Assert.True(connectionInfo.IntellisenseMetrics.Quantile.Any());
|
|
}
|
|
|
|
private ScriptDocumentInfo CreateScriptDocumentInfo()
|
|
{
|
|
TextDocumentPosition doc = new TextDocumentPosition()
|
|
{
|
|
TextDocument = new TextDocumentIdentifier
|
|
{
|
|
Uri = "script file"
|
|
},
|
|
Position = new Position()
|
|
{
|
|
Line = 1,
|
|
Character = 14
|
|
}
|
|
};
|
|
ScriptFile scriptFile = new ScriptFile()
|
|
{
|
|
Contents = "Select * from sys.all_objects"
|
|
};
|
|
|
|
ScriptParseInfo scriptParseInfo = new ScriptParseInfo() { IsConnected = true };
|
|
ScriptDocumentInfo docInfo = new ScriptDocumentInfo(doc, scriptFile, scriptParseInfo);
|
|
|
|
return docInfo;
|
|
}
|
|
}
|
|
}
|