|
' Licensed to the .NET Foundation under one or more agreements.
' The .NET Foundation licenses this file to you under the MIT license.
' See the LICENSE file in the project root for more information.
Imports System.Collections.Immutable
Imports System.Threading
Imports Microsoft.CodeAnalysis
Imports Microsoft.CodeAnalysis.CodeCleanup
Imports Microsoft.CodeAnalysis.Editor.UnitTests.Extensions
Imports Microsoft.CodeAnalysis.Formatting
Imports Microsoft.CodeAnalysis.Simplification
Imports Microsoft.CodeAnalysis.Text
Namespace Microsoft.CodeAnalysis.Editor.UnitTests.Expansion
<[UseExportProvider]>
Public MustInherit Class AbstractExpansionTest
Protected Shared Async Function TestAsync(definition As XElement, expected As XElement, Optional useLastProject As Boolean = False, Optional expandParameter As Boolean = False) As System.Threading.Tasks.Task
Using workspace = EditorTestWorkspace.Create(definition)
Dim hostDocument = If(Not useLastProject, workspace.Documents.Single(), workspace.Documents.Last())
If hostDocument.AnnotatedSpans.Count <> 1 Then
Assert.True(False, "Encountered unexpected span annotation -- only one of 'Expand' or 'ExpandAndSimplify' is legal")
End If
Dim document = If(Not useLastProject, workspace.CurrentSolution.Projects.Single(), workspace.CurrentSolution.Projects.Last()).Documents.Single()
Dim root = Await document.GetSyntaxRootAsync()
Dim cleanupOptions = Await document.GetCodeCleanupOptionsAsync(CancellationToken.None)
Dim spans As ImmutableArray(Of TextSpan) = Nothing
If hostDocument.AnnotatedSpans.TryGetValue("Expand", spans) Then
For Each span In spans
Dim node = GetExpressionSyntaxWithSameSpan(root.FindToken(span.Start).Parent, span.End)
root = root.ReplaceNode(node, Await Simplifier.ExpandAsync(node, document, expandInsideNode:=Nothing, expandParameter:=expandParameter))
Next
ElseIf hostDocument.AnnotatedSpans.TryGetValue("ExpandAndSimplify", spans) Then
For Each span In spans
Dim node = GetExpressionSyntaxWithSameSpan(root.FindToken(span.Start).Parent, span.End)
root = root.ReplaceNode(node, Await Simplifier.ExpandAsync(node, document, expandInsideNode:=Nothing, expandParameter:=expandParameter))
document = document.WithSyntaxRoot(root)
document = Await Simplifier.ReduceAsync(document, Simplifier.Annotation, cleanupOptions.SimplifierOptions, CancellationToken.None)
root = Await document.GetSyntaxRootAsync()
Next
End If
document = document.WithSyntaxRoot(root)
document = Await Formatter.FormatAsync(document, cleanupOptions.FormattingOptions, CancellationToken.None)
Dim actualText = (Await document.GetTextAsync()).ToString()
Assert.Equal(expected.NormalizedValue.Trim(), actualText.Trim())
End Using
End Function
Private Shared Function GetExpressionSyntaxWithSameSpan(node As SyntaxNode, spanEnd As Integer) As SyntaxNode
While node IsNot Nothing And node.Parent IsNot Nothing And node.Parent.SpanStart = node.SpanStart
node = node.Parent
If node.Span.End = spanEnd Then
Exit While
End If
End While
Return node
End Function
End Class
End Namespace
|