コード例 #1
0
        public void TestFindReferencesSynchronousCall()
        {
            using (var workspace = CSharpWorkspaceFactory.CreateWorkspaceFromLines("class C { C() { new C(); } }"))
            {
                var findReferencesPresenter = new MockReferencedSymbolsPresenter();

                var handler = new FindReferencesCommandHandler(
                    TestWaitIndicator.Default,
                    SpecializedCollections.SingletonEnumerable(findReferencesPresenter));

                var textView = workspace.Documents[0].GetTextView();
                textView.Caret.MoveTo(new SnapshotPoint(textView.TextSnapshot, 7));
                handler.ExecuteCommand(new FindReferencesCommandArgs(
                                           textView,
                                           textView.TextBuffer), () => { });

                AssertResult(findReferencesPresenter.Result, "C", ".ctor");
            }
        }
コード例 #2
0
        public void CSharpOutliningTagger()
        {
            var code = new string[]
            {
                "using System;",
                "namespace MyNamespace",
                "{",
                "#region MyRegion",
                "    public class MyClass",
                "    {",
                "        static void Main(string[] args)",
                "        {",
                "            int x = 5;",
                "        }",
                "    }",
                "#endregion",
                "}"
            };

            using (var workspace = CSharpWorkspaceFactory.CreateWorkspaceFromLines(code))
            {
                var tags = GetTagsFromWorkspace(workspace);

                // ensure all 4 outlining region tags were found
                Assert.Equal(4, tags.Count);

                // ensure the method and #region outlining spans are marked as implementation
                Assert.False(tags[0].IsImplementation);
                Assert.False(tags[1].IsImplementation);
                Assert.True(tags[2].IsImplementation);
                Assert.True(tags[3].IsImplementation);

                // verify line counts
                var hints = tags.Select(x => x.CollapsedHintForm).Cast<ViewHostingControl>().Select(vhc => vhc.TextView_TestOnly).ToList();
                Assert.Equal(12, hints[0].TextSnapshot.LineCount); // namespace
                Assert.Equal(7, hints[1].TextSnapshot.LineCount); // class
                Assert.Equal(9, hints[2].TextSnapshot.LineCount); // region
                Assert.Equal(4, hints[3].TextSnapshot.LineCount); // method
                hints.Do(v => v.Close());
            }
        }
コード例 #3
0
        protected void AssertFormat(string expected, string code, IEnumerable <TextSpan> spans, bool debugMode = false, Dictionary <OptionKey, object> changedOptionSet = null, int?baseIndentation = null)
        {
            using (var workspace = CSharpWorkspaceFactory.CreateWorkspaceFromLines(code))
            {
                var hostdoc = workspace.Documents.First();
                var buffer  = hostdoc.GetTextBuffer();

                var document   = workspace.CurrentSolution.GetDocument(hostdoc.Id);
                var syntaxTree = document.GetSyntaxTreeAsync().Result;

                // create new buffer with cloned content
                var clonedBuffer = EditorFactory.CreateBuffer(
                    buffer.ContentType.TypeName,
                    workspace.ExportProvider,
                    buffer.CurrentSnapshot.GetText());

                var formattingRuleProvider = workspace.Services.GetService <IHostDependentFormattingRuleFactoryService>();
                if (baseIndentation.HasValue)
                {
                    var factory = formattingRuleProvider as TestFormattingRuleFactoryServiceFactory.Factory;
                    factory.BaseIndentation = baseIndentation.Value;
                    factory.TextSpan        = spans.First();
                }

                var options = workspace.Options;
                if (changedOptionSet != null)
                {
                    foreach (var entry in changedOptionSet)
                    {
                        options = options.WithChangedOption(entry.Key, entry.Value);
                    }
                }

                var root  = syntaxTree.GetRoot();
                var rules = formattingRuleProvider.CreateRule(workspace.CurrentSolution.GetDocument(syntaxTree), 0).Concat(Formatter.GetDefaultFormattingRules(workspace, root.Language));
                AssertFormat(workspace, expected, options, rules, clonedBuffer, root, spans);

                // format with node and transform
                AssertFormatWithTransformation(workspace, expected, options, rules, root, spans);
            }
        }
コード例 #4
0
        public void AnalyzeDocumentAsync_SemanticError_Change()
        {
            string source1  = @"
class C
{
    public static void Main()
    {
        System.Console.WriteLine(1);
        Bar(); // semantic error
    }
}
";
            string source2  = @"
class C
{
    public static void Main()
    {
        System.Console.WriteLine(2);
        Bar(); // semantic error
    }
}
";
            var    analyzer = new CSharpEditAndContinueAnalyzer();

            using (var workspace = CSharpWorkspaceFactory.CreateWorkspaceFromLines(source1))
            {
                var documentId  = workspace.CurrentSolution.Projects.First().Documents.First().Id;
                var oldSolution = workspace.CurrentSolution;
                var newSolution = workspace.CurrentSolution.WithDocumentText(documentId, SourceText.From(source2));

                var baseActiveStatements = ImmutableArray.Create <ActiveStatementSpan>();
                var result = analyzer.AnalyzeDocumentAsync(oldSolution, baseActiveStatements, newSolution.GetDocument(documentId), default(CancellationToken)).Result;

                Assert.True(result.HasChanges);
                Assert.True(result.HasChangesAndErrors);
                Assert.True(result.HasChangesAndCompilationErrors);
            }
        }
コード例 #5
0
        protected void ExpectExtractMethodToFail(
            string codeWithMarker,
            string expected,
            bool allowMovingDeclaration     = true,
            bool dontPutOutOrRefOnStruct    = true,
            CSharpParseOptions parseOptions = null)
        {
            using (var workspace = CSharpWorkspaceFactory.CreateWorkspaceFromLines(new[] { codeWithMarker }, parseOptions: parseOptions))
            {
                var testDocument  = workspace.Documents.Single();
                var subjectBuffer = testDocument.TextBuffer;

                var tree = ExtractMethod(workspace, testDocument, succeed: false, allowMovingDeclaration: allowMovingDeclaration, dontPutOutOrRefOnStruct: dontPutOutOrRefOnStruct);

                using (var edit = subjectBuffer.CreateEdit())
                {
                    edit.Replace(0, edit.Snapshot.Length, tree.ToFullString());
                    edit.Apply();
                }

                Assert.Equal(expected, subjectBuffer.CurrentSnapshot.GetText());
            }
        }
コード例 #6
0
        protected int GetSmartTokenFormatterIndentation(
            string code,
            int indentationLine,
            char ch,
            int?baseIndentation = null,
            TextSpan span       = default(TextSpan))
        {
            // create tree service
            using (var workspace = CSharpWorkspaceFactory.CreateWorkspaceFromLines(code))
            {
                if (baseIndentation.HasValue)
                {
                    var factory = workspace.Services.GetService <IHostDependentFormattingRuleFactoryService>()
                                  as TestFormattingRuleFactoryServiceFactory.Factory;

                    factory.BaseIndentation = baseIndentation.Value;
                    factory.TextSpan        = span;
                }

                var buffer = workspace.Documents.First().GetTextBuffer();
                return(GetSmartTokenFormatterIndentationWorker(workspace, buffer, indentationLine, ch));
            }
        }
コード例 #7
0
        public void AnalyzeDocumentAsync_SyntaxError_NoChange()
        {
            string source   = @"
class C
{
    public static void Main()
    {
        System.Console.WriteLine(1) // syntax error
    }
}
";
            var    analyzer = new CSharpEditAndContinueAnalyzer();

            using (var workspace = CSharpWorkspaceFactory.CreateWorkspaceFromLines(source))
            {
                var document             = workspace.CurrentSolution.Projects.First().Documents.First();
                var baseActiveStatements = ImmutableArray.Create <ActiveStatementSpan>();
                var result = analyzer.AnalyzeDocumentAsync(workspace.CurrentSolution, baseActiveStatements, document, default(CancellationToken)).Result;

                Assert.False(result.HasChanges);
                Assert.False(result.HasChangesAndErrors);
                Assert.False(result.HasChangesAndCompilationErrors);
            }
        }
コード例 #8
0
        protected static void AssertFormatWithView(string expectedWithMarker, string codeWithMarker, bool debugMode = false)
        {
            var editorOperations = new Mock <IEditorOperations>(MockBehavior.Strict);
            var editorOperationsFactoryService = new Mock <IEditorOperationsFactoryService>(MockBehavior.Strict);

            editorOperations.Setup(o => o.AddAfterTextBufferChangePrimitive());
            editorOperations.Setup(o => o.AddBeforeTextBufferChangePrimitive());

            editorOperationsFactoryService.Setup(s => s.GetEditorOperations(It.IsAny <ITextView>())).Returns(editorOperations.Object);

            using (var workspace = CSharpWorkspaceFactory.CreateWorkspaceFromLines(codeWithMarker))
            {
                // set up caret position
                var testDocument = workspace.Documents.Single();
                var view         = testDocument.GetTextView();
                view.Caret.MoveTo(new SnapshotPoint(view.TextSnapshot, testDocument.CursorPosition.Value));

                // get original buffer
                var buffer = workspace.Documents.First().GetTextBuffer();

                var commandHandler = new FormatCommandHandler(TestWaitIndicator.Default, workspace.GetService <ITextUndoHistoryRegistry>(), editorOperationsFactoryService.Object);

                var commandArgs = new FormatDocumentCommandArgs(view, view.TextBuffer);
                commandHandler.ExecuteCommand(commandArgs, () => { });

                string expected;
                int    expectedPosition;
                MarkupTestFile.GetPosition(expectedWithMarker, out expected, out expectedPosition);

                Assert.Equal(expected, view.TextSnapshot.GetText());

                var caretPosition = view.Caret.Position.BufferPosition.Position;
                Assert.True(expectedPosition == caretPosition,
                            string.Format("Caret positioned incorrectly. Should have been {0}, but was {1}.", expectedPosition, caretPosition));
            }
        }
コード例 #9
0
        private void TestCaching(string markup, params string[][] expectedArray)
        {
            using (var workspace = CSharpWorkspaceFactory.CreateWorkspaceFromLines(markup))
            {
                var testDocument      = workspace.Documents.Single();
                var spans             = testDocument.AnnotatedSpans;
                var snapshot          = testDocument.TextBuffer.CurrentSnapshot;
                var languageDebugInfo = new CachedProximityExpressionsGetter(new CSharpProximityExpressionsService());
                var document          = workspace.CurrentSolution.GetDocument(testDocument.Id);

                for (var i = 0; i < expectedArray.Length; i++)
                {
                    int position;
                    var key = spans.Keys.FirstOrDefault(k => k.StartsWith(i + "-", StringComparison.Ordinal));
                    if (key != null)
                    {
                        var parts = key.Split('-');
                        if (parts[1] == "OnDebugModeChanged")
                        {
                            languageDebugInfo.OnDebugModeChanged((DebugMode)Enum.Parse(typeof(DebugMode), parts[2]));
                        }

                        position = spans[key].First().Start;
                    }
                    else
                    {
                        position = spans[i.ToString()].First().Start;
                    }

                    var expected = expectedArray[i];

                    var result = languageDebugInfo.DoAsync(document, position, string.Empty, CancellationToken.None).Result;
                    AssertEx.Equal(expectedArray[i], result);
                }
            }
        }
コード例 #10
0
 protected override TestWorkspace CreateWorkspaceFromCode(string code)
 {
     return(CSharpWorkspaceFactory.CreateWorkspaceFromLines(code));
 }
コード例 #11
0
 protected override TestWorkspace CreateTestWorkspace(string initialMarkup)
 {
     return(CSharpWorkspaceFactory.CreateWorkspaceFromLines(initialMarkup));
 }
コード例 #12
0
        public void TestPreviewDiagnosticTaggerInPreviewPane()
        {
            using (var workspace = CSharpWorkspaceFactory.CreateWorkspaceFromLines("class { }"))
            {
                // set up listener to wait until diagnostic finish running
                var diagnosticService = workspace.ExportProvider.GetExportedValue <IDiagnosticService>() as DiagnosticService;

                // no easy way to setup waiter. kind of hacky way to setup waiter
                var source     = new CancellationTokenSource();
                var taskSource = new TaskCompletionSource <DiagnosticsUpdatedArgs>();
                diagnosticService.DiagnosticsUpdated += (s, a) =>
                {
                    source.Cancel();

                    source = new CancellationTokenSource();
                    var cancellationToken = source.Token;
                    Task.Delay(2000, cancellationToken).ContinueWith(t => taskSource.TrySetResult(a), CancellationToken.None, TaskContinuationOptions.OnlyOnRanToCompletion, TaskScheduler.Current);
                };

                var hostDocument = workspace.Projects.First().Documents.First();

                // make a change to remove squiggle
                var oldDocument = workspace.CurrentSolution.GetDocument(hostDocument.Id);
                var oldText     = oldDocument.GetTextAsync().Result;

                var newDocument = oldDocument.WithText(oldText.WithChanges(new TextChange(new TextSpan(0, oldText.Length), "class C { }")));

                // create a diff view
                var previewFactoryService = workspace.ExportProvider.GetExportedValue <IPreviewFactoryService>();
                var diffView = (IWpfDifferenceViewer)previewFactoryService.CreateChangedDocumentPreviewViewAsync(oldDocument, newDocument, CancellationToken.None).PumpingWaitResult();

                var foregroundService = workspace.GetService <IForegroundNotificationService>();
                var optionsService    = workspace.Services.GetService <IOptionService>();

                var waiter    = new ErrorSquiggleWaiter();
                var listeners = AsynchronousOperationListener.CreateListeners(FeatureAttribute.ErrorSquiggles, waiter);

                // set up tagger for both buffers
                var leftBuffer   = diffView.LeftView.BufferGraph.GetTextBuffers(t => t.ContentType.IsOfType(ContentTypeNames.CSharpContentType)).First();
                var leftProvider = new DiagnosticsSquiggleTaggerProvider(optionsService, diagnosticService, foregroundService, listeners);
                var leftTagger   = leftProvider.CreateTagger <IErrorTag>(leftBuffer);
                using (var leftDisposable = leftTagger as IDisposable)
                {
                    var rightBuffer   = diffView.RightView.BufferGraph.GetTextBuffers(t => t.ContentType.IsOfType(ContentTypeNames.CSharpContentType)).First();
                    var rightProvider = new DiagnosticsSquiggleTaggerProvider(optionsService, diagnosticService, foregroundService, listeners);
                    var rightTagger   = rightProvider.CreateTagger <IErrorTag>(rightBuffer);
                    using (var rightDisposable = rightTagger as IDisposable)
                    {
                        // wait up to 20 seconds for diagnostics
                        taskSource.Task.Wait(20000);
                        if (!taskSource.Task.IsCompleted)
                        {
                            // something is wrong
                            FatalError.Report(new System.Exception("not finished after 20 seconds"));
                        }

                        // wait taggers
                        waiter.CreateWaitTask().PumpingWait();

                        // check left buffer
                        var leftSnapshot = leftBuffer.CurrentSnapshot;
                        var leftSpans    = leftTagger.GetTags(leftSnapshot.GetSnapshotSpanCollection()).ToList();
                        Assert.Equal(1, leftSpans.Count);

                        // check right buffer
                        var rightSnapshot = rightBuffer.CurrentSnapshot;
                        var rightSpans    = rightTagger.GetTags(rightSnapshot.GetSnapshotSpanCollection()).ToList();
                        Assert.Equal(0, rightSpans.Count);
                    }
                }
            }
        }
コード例 #13
0
        public void GenerateBaseline()
        {
            Console.WriteLine(typeof(FactAttribute));

            var text = Resources.ProximityExpressionsGetterTestFile;

            using (var workspace = CSharpWorkspaceFactory.CreateWorkspaceFromLines(text))
            {
                var languageDebugInfo = new CSharpLanguageDebugInfoService();

                var hostdoc  = workspace.Documents.First();
                var snapshot = hostdoc.TextBuffer.CurrentSnapshot;
                var document = workspace.CurrentSolution.GetDocument(hostdoc.Id);

                var builder    = new StringBuilder();
                var statements = document.GetCSharpSyntaxRootAsync(CancellationToken.None).WaitAndGetResult(CancellationToken.None).DescendantTokens().Select(t => t.GetAncestor <StatementSyntax>()).Distinct().WhereNotNull();

                // Try to get proximity expressions at every token position and the start of every
                // line.
                var index = 0;
                foreach (var statement in statements)
                {
                    builder.AppendLine("[Fact, Trait(Traits.Feature, Traits.Features.DebuggingProximityExpressions)]");
                    builder.AppendLine("public void TestAtStartOfStatement_" + index + "()");
                    builder.AppendLine("{");

                    var token = statement.GetFirstToken();
                    var line  = snapshot.GetLineFromPosition(token.SpanStart);

                    builder.AppendLine("    //// Line " + (line.LineNumber + 1));
                    builder.AppendLine();
                    if (line.LineNumber > 0)
                    {
                        builder.AppendLine("    //// " + snapshot.GetLineFromLineNumber(line.LineNumber - 1).GetText());
                    }

                    builder.AppendLine("    //// " + line.GetText());
                    var charIndex = token.SpanStart - line.Start;
                    builder.AppendLine("    //// " + new string(' ', charIndex) + "^");
                    builder.AppendLine("    var tree = GetTree(\"ProximityExpressionsGetterTestFile.cs\");");
                    builder.AppendLine("    var terms = CSharpProximityExpressionsService.Do(tree, " + token.SpanStart + ");");

                    var proximityExpressionsGetter = new CSharpProximityExpressionsService();
                    var terms = proximityExpressionsGetter.GetProximityExpressionsAsync(document, token.SpanStart, CancellationToken.None).Result;
                    if (terms == null)
                    {
                        builder.AppendLine("    Assert.Null(terms);");
                    }
                    else
                    {
                        builder.AppendLine("    Assert.NotNull(terms);");

                        var termsString = terms.Select(t => "\"" + t + "\"").Join(", ");
                        builder.AppendLine("    AssertEx.Equal(new[] { " + termsString + " }, terms);");
                    }

                    builder.AppendLine("}");
                    builder.AppendLine();
                    index++;
                }

                var str = builder.ToString();
                Console.WriteLine(str);
            }
        }