From fdb17921e59c40307a55c1421999c2ea4f3a179c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Bj=C3=B6rkstr=C3=B6m?= Date: Tue, 15 Sep 2020 23:12:15 +0300 Subject: [PATCH 1/2] Adds QuickInfo support for Cake --- .../RequestHandlers/QuickInfoHandler.cs | 16 ++++ tests/OmniSharp.Cake.Tests/QuickInfoFacts.cs | 81 +++++++++++++++++++ 2 files changed, 97 insertions(+) create mode 100644 src/OmniSharp.Cake/Services/RequestHandlers/QuickInfoHandler.cs create mode 100644 tests/OmniSharp.Cake.Tests/QuickInfoFacts.cs diff --git a/src/OmniSharp.Cake/Services/RequestHandlers/QuickInfoHandler.cs b/src/OmniSharp.Cake/Services/RequestHandlers/QuickInfoHandler.cs new file mode 100644 index 0000000000..b3aa32f193 --- /dev/null +++ b/src/OmniSharp.Cake/Services/RequestHandlers/QuickInfoHandler.cs @@ -0,0 +1,16 @@ +using System.Composition; +using OmniSharp.Mef; +using OmniSharp.Models; + +namespace OmniSharp.Cake.Services.RequestHandlers +{ + [Shared] + [OmniSharpHandler(OmniSharpEndpoints.QuickInfo, Constants.LanguageNames.Cake)] + public class QuickInfoHandler : CakeRequestHandler + { + [ImportingConstructor] + public QuickInfoHandler(OmniSharpWorkspace workspace) : base(workspace) + { + } + } +} diff --git a/tests/OmniSharp.Cake.Tests/QuickInfoFacts.cs b/tests/OmniSharp.Cake.Tests/QuickInfoFacts.cs new file mode 100644 index 0000000000..0c5ac6040a --- /dev/null +++ b/tests/OmniSharp.Cake.Tests/QuickInfoFacts.cs @@ -0,0 +1,81 @@ +using System.Collections.Generic; +using System.IO; +using System.Linq; +using System.Threading; +using System.Threading.Tasks; +using Microsoft.Extensions.Logging; +using OmniSharp.Cake.Services.RequestHandlers; +using OmniSharp.Cake.Services.RequestHandlers.Completion; +using OmniSharp.Models; +using OmniSharp.Models.UpdateBuffer; +using OmniSharp.Models.v1.Completion; +using TestUtility; +using Xunit; +using Xunit.Abstractions; + +namespace OmniSharp.Cake.Tests +{ + public class QuickInfoFacts : CakeSingleRequestHandlerTestFixture + { + private readonly ILogger _logger; + + public QuickInfoFacts(ITestOutputHelper testOutput) : base(testOutput) + { + _logger = LoggerFactory.CreateLogger(); + } + + protected override string EndpointName => OmniSharpEndpoints.QuickInfo; + + [Fact] + public async Task ShouldGetQuickInfo() + { + const string input = "Informa$$tion(\"Hello\");"; + + using (var testProject = await TestAssets.Instance.GetTestProjectAsync("CakeProject", shadowCopy : false)) + using (var host = CreateOmniSharpHost(testProject.Directory)) + { + var fileName = Path.Combine(testProject.Directory, "build.cake"); + var quickInfo = await GetQuickInfo(fileName, input, host); + + Assert.StartsWith("```csharp\nvoid Information(string value)", quickInfo.Markdown); + } + } + + private async Task GetQuickInfo(string filename, string source, OmniSharpTestHost host, char? triggerChar = null, TestFile[] additionalFiles = null) + { + var testFile = new TestFile(filename, source); + + var files = new[] { testFile }; + if (additionalFiles is object) + { + files = files.Concat(additionalFiles).ToArray(); + } + + host.AddFilesToWorkspace(files); + var point = testFile.Content.GetPointFromPosition(); + + var request = new QuickInfoRequest + { + Line = point.Line, + Column = point.Offset, + FileName = testFile.FileName, + Buffer = testFile.Content.Code + }; + + var updateBufferRequest = new UpdateBufferRequest + { + Buffer = request.Buffer, + Column = request.Column, + FileName = request.FileName, + Line = request.Line, + FromDisk = false + }; + + await GetUpdateBufferHandler(host).Handle(updateBufferRequest); + + var requestHandler = GetRequestHandler(host); + + return await requestHandler.Handle(request); + } + } +} From 8539f57bc08158c927b51568e1479d33396f5f18 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Bj=C3=B6rkstr=C3=B6m?= Date: Tue, 15 Sep 2020 23:16:44 +0300 Subject: [PATCH 2/2] Add release notes. --- CHANGELOG.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 3cf2a07d1b..2619d4832a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,9 @@ # Changelog All changes to the project will be documented in this file. +## [1.37.2] - Not Yet Released +* Add support for new quick info endpoint when working with Cake (PR: [#1945](https://github.com/OmniSharp/omnisharp-roslyn/pull/1945)) + ## [1.37.1] - 2020-09-01 * Ensure that all quickinfo sections have linebreaks between them, and don't add unecessary duplicate linebreaks (PR: [#1900](https://github.com/OmniSharp/omnisharp-roslyn/pull/1900)) * Support completion of unimported types (PR: [#1896](https://github.com/OmniSharp/omnisharp-roslyn/pull/1896))