File: Microsoft.CodeQuality.Analyzers\ApiDesignGuidelines\IdentifiersShouldNotHaveIncorrectSuffixTests.cs
Web Access
Project: ..\..\..\src\Microsoft.CodeAnalysis.NetAnalyzers\tests\Microsoft.CodeAnalysis.NetAnalyzers.UnitTests\Microsoft.CodeAnalysis.NetAnalyzers.UnitTests.csproj (Microsoft.CodeAnalysis.NetAnalyzers.UnitTests)
// Copyright (c) Microsoft.  All Rights Reserved.  Licensed under the MIT license.  See License.txt in the project root for license information.
 
using System.Threading.Tasks;
using Microsoft.CodeAnalysis;
using Microsoft.CodeAnalysis.Testing;
using Xunit;
using VerifyCS = Test.Utilities.CSharpCodeFixVerifier<
    Microsoft.CodeQuality.Analyzers.ApiDesignGuidelines.IdentifiersShouldNotHaveIncorrectSuffixAnalyzer,
    Microsoft.CodeQuality.CSharp.Analyzers.ApiDesignGuidelines.CSharpIdentifiersShouldNotHaveIncorrectSuffixFixer>;
using VerifyVB = Test.Utilities.VisualBasicCodeFixVerifier<
    Microsoft.CodeQuality.Analyzers.ApiDesignGuidelines.IdentifiersShouldNotHaveIncorrectSuffixAnalyzer,
    Microsoft.CodeQuality.VisualBasic.Analyzers.ApiDesignGuidelines.BasicIdentifiersShouldNotHaveIncorrectSuffixFixer>;
 
namespace Microsoft.CodeQuality.Analyzers.ApiDesignGuidelines.UnitTests
{
    public class IdentifiersShouldNotHaveIncorrectSuffixTests
    {
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeDoesNotDeriveFromAttributeAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBadAttribute {}",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadAttribute",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.AttributeSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeDoesNotDeriveFromAttributeAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBadAttribute
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadAttribute",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.AttributeSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromAttributeAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System;
 
public class MyAttribute : Attribute {}
public class MyOtherAttribute : MyAttribute {}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromAttributeAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System
 
Public Class MyAttribute
    Inherits Attribute
End Class
 
Public Class MyOtherAttribute
    Inherits MyAttribute
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeDoesNotDeriveFromEventArgsAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
                "public class MyBadEventArgs {}",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadEventArgs",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.EventArgsSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeDoesNotDeriveFromEventArgsAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBadEventArgs
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadEventArgs",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.EventArgsSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromEventArgsAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System;
 
public class MyEventArgs : EventArgs {}
public class MyOtherEventArgs : MyEventArgs {}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromEventArgsAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System
 
Public Class MyEventArgs
    Inherits EventArgs
End Class
 
Public Class MyOtherEventArgs
    Inherits MyEventArgs
End Class");
        }
 
        // There's no need for a test case where the type is derived from EventHandler
        // or EventHandler<T>, because they're sealed.
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeNameEndsWithEventHandlerAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBadEventHandler {}",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadEventHandler",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.EventHandlerSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeNameEndsWithEventHandlerAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBadEventHandler
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadEventHandler",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.EventHandlerSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeDoesNotDeriveFromExceptionAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBadException {}",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadException",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExceptionSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeDoesNotDeriveFromExceptionAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBadException
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadException",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExceptionSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromExceptionAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System;
 
public class MyException : Exception {}
public class MyOtherException : MyException {}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromExceptionAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System
 
Public Class MyException
    Inherits Exception
End Class
 
Public Class MyOtherException
    Inherits MyException
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeDoesNotDeriveFromIPermissionAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBadPermission {}",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadPermission",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.PermissionSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeDoesNotDeriveFromIPermissionAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBadPermission
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadPermission",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.PermissionSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromIPermissionAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.Security;
 
public class MyPermission : IPermission
{
    public IPermission Copy() { return null; }
    public void Demand() {}
    public void FromXml(SecurityElement e) {}
    public IPermission Intersect(IPermission other) { return null; }
    public bool IsSubsetOf(IPermission target) { return false; }
    public SecurityElement ToXml() { return null; }
    public IPermission Union(IPermission other) { return null; }
}
 
public class MyOtherPermission : MyPermission {}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromIPermissionAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Security
 
Public Class MyPermission
    Implements IPermission
 
    Public Sub Demand() Implements IPermission.Demand
    End Sub
 
    Public Sub FromXml(e As SecurityElement) Implements ISecurityEncodable.FromXml
    End Sub
 
    Public Function Copy() As IPermission Implements IPermission.Copy
        Return Nothing
    End Function
 
    Public Function Intersect(target As IPermission) As IPermission Implements IPermission.Intersect
        Return Nothing
    End Function
 
    Public Function IsSubsetOf(target As IPermission) As Boolean Implements IPermission.IsSubsetOf
        Return False
    End Function
 
    Public Function ToXml() As SecurityElement Implements ISecurityEncodable.ToXml
        Return Nothing
    End Function
 
    Public Function Union(target As IPermission) As IPermission Implements IPermission.Union
        Return Nothing
    End Function
End Class
 
Public Class MyOtherPermission
    Inherits MyPermission
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeDoesNotDeriveFromStreamAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBadStream {}",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadStream",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.StreamSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeDoesNotDeriveFromStreamAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBadStream
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadStream",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.StreamSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromStreamAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.IO;
 
public class MyStream : Stream
{
    public override bool CanRead => false;
    public override bool CanSeek => false;
    public override bool CanWrite => false;
    public override long Length => 0L;
 
    public override long Position
    {
        get { return 0L; }
        set { }
    }
 
    public override void Flush() { }
 
    public override int Read(byte[] buffer, int offset, int count)
    {
        return 0;
    }
 
    public override long Seek(long offset, SeekOrigin origin)
    {
        return 0L;
    }
 
    public override void SetLength(long value) { }
 
    public override void Write(byte[] buffer, int offset, int count) { }
}
 
public class MyOtherStream : MyStream { }");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromStreamAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.IO
 
Public Class MyStream
    Inherits Stream
 
    Public Overrides ReadOnly Property CanRead As Boolean
        Get
            Return False
        End Get
    End Property
 
    Public Overrides ReadOnly Property CanSeek As Boolean
        Get
            Return False
        End Get
    End Property
 
    Public Overrides ReadOnly Property CanWrite As Boolean
        Get
            Return False
        End Get
    End Property
 
    Public Overrides ReadOnly Property Length As Long
        Get
            Return 0
        End Get
    End Property
 
    Public Overrides Property Position As Long
        Get
            Return 0
        End Get
        Set(value As Long)
        End Set
    End Property
 
    Public Overrides Sub Flush()
    End Sub
 
    Public Overrides Sub SetLength(value As Long)
    End Sub
 
    Public Overrides Sub Write(buffer() As Byte, offset As Integer, count As Integer)
    End Sub
 
    Public Overrides Function Read(buffer() As Byte, offset As Integer, count As Integer) As Integer
        Return 0
    End Function
 
    Public Overrides Function Seek(offset As Long, origin As SeekOrigin) As Long
        Return 0
    End Function
 
    Public Sub SomeMethodNotPresentInStream()
    End Sub
End Class
 
Public Class MyOtherStream
    Inherits MyStream
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeNameEndsWithDelegateAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public delegate void MyBadDelegate();",
                GetCSharpResultAt(
                    1, 22,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadDelegate",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.DelegateSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeNameEndsWithDelegateAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Delegate Sub MyBadDelegate()",
                GetBasicResultAt(
                    1, 21,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadDelegate",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.DelegateSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeNameEndsWithEnumAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public enum MyBadEnum { X }",
                GetCSharpResultAt(
                    1, 13,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadEnum",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.EnumSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeNameEndsWithEnumAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Enum MyBadEnum
    X
End Enum",
                GetBasicResultAt(
                    1, 13,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadEnum",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.EnumSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeNameEndsWithImplAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClassImpl {}",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberWithAlternateRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ImplSuffix,
                    "MyClassImpl",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CoreSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeNameEndsWithImplAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyClassImpl
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberWithAlternateRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ImplSuffix,
                    "MyClassImpl",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CoreSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeNamingRulesAreCaseSensitiveEvenInVBAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyClassimpl
End Class");
        }
 
        [Fact]
        public async Task CSharp_No_Diagnostic_MisnamedTypeIsInternalAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"internal class MyClassImpl {}");
        }
 
        [Fact]
        public async Task Basic_No_Diagnostic_MisnamedTypeIsInternalAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Friend Class MyClassImpl
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_MisnamedTypeIsNestedPublicAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClass
{
    public class MyNestedClassImpl {}
}",
                GetCSharpResultAt(
                    3, 18,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberWithAlternateRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ImplSuffix,
                    "MyNestedClassImpl",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CoreSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_MisnamedTypeIsNestedPublicAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class [MyClass]
    Public Class MyNestedClassImpl
    End Class
End Class",
                GetBasicResultAt(
                    2, 18,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberWithAlternateRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ImplSuffix,
                    "MyNestedClassImpl",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CoreSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_MisnamedTypeIsNestedProtectedAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClass
{
    protected class MyNestedClassImpl {}
}",
                GetCSharpResultAt(
                    3, 21,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberWithAlternateRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ImplSuffix,
                    "MyNestedClassImpl",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CoreSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_MisnamedTypeIsNestedProtectedAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class [MyClass]
    Protected Class MyNestedClassImpl
    End Class
End Class",
                GetBasicResultAt(
                    2, 21,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberWithAlternateRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ImplSuffix,
                    "MyNestedClassImpl",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CoreSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_MisnamedTypeIsNestedPrivateAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClass
{
    private class MyNestedClassImpl {}
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_MisnamedTypeIsNestedPrivateAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class [MyClass]
    Private Class MyNestedClassImpl
    End Class
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeDoesNotDeriveFromDictionaryAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBadDictionary {}",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadDictionary",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.DictionarySuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeDoesNotDeriveFromDictionaryAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBadDictionary
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadDictionary",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.DictionarySuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeImplementsIReadOnlyDictionaryAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.Collections;
using System.Collections.Generic;
 
public class MyReadOnlyDictionary : IReadOnlyDictionary<string, int>
{
    public int this[string key] => 0;
    public int Count => 0;
    public IEnumerable<string> Keys => new string[0];
    public IEnumerable<int> Values => new int[0];
 
    public bool ContainsKey(string key) { return false; }
    public IEnumerator<KeyValuePair<string, int>> GetEnumerator() { return null; }
    IEnumerator IEnumerable.GetEnumerator() { return null; }
 
    public bool TryGetValue(string key, out int value)
    {
        value = -1;
        return false;
    }
}");
        }
 
        [Fact]
        public async Task CA1711_BasicNoDiagnostic_TypeImplementsIReadOnlyDictionaryAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Collections
Imports System.Collections.Generic
 
Public Class MyReadOnlyDictionary
    Implements IReadOnlyDictionary(Of String, Integer)
 
    Public ReadOnly Property Count As Integer Implements IReadOnlyCollection(Of KeyValuePair(Of String, Integer)).Count
        Get
            Return 0
        End Get
    End Property
 
    Default Public ReadOnly Property Item(key As String) As Integer Implements IReadOnlyDictionary(Of String, Integer).Item
        Get
            Return 0
        End Get
    End Property
 
    Public ReadOnly Property Keys As IEnumerable(Of String) Implements IReadOnlyDictionary(Of String, Integer).Keys
        Get
            Return New String() { }
        End Get
    End Property
 
    Public ReadOnly Property Values As IEnumerable(Of Integer) Implements IReadOnlyDictionary(Of String, Integer).Values
        Get
            Return New Integer() { }
        End Get
    End Property
 
    Public Function ContainsKey(key As String) As Boolean Implements IReadOnlyDictionary(Of String, Integer).ContainsKey
        Return False
    End Function
 
    Public Function GetEnumerator() As IEnumerator(Of KeyValuePair(Of String, Integer)) Implements IEnumerable(Of KeyValuePair(Of String, Integer)).GetEnumerator
        Return Nothing
    End Function
 
    Public Function TryGetValue(key As String, ByRef value As Integer) As Boolean Implements IReadOnlyDictionary(Of String, Integer).TryGetValue
        value = -1
        Return False
    End Function
 
    Private Function IEnumerable_GetEnumerator() As IEnumerator Implements IEnumerable.GetEnumerator
        Return Nothing
    End Function
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeImplementsGenericIDictionaryAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System;
using System.Collections;
using System.Collections.Generic;
 
public class MyGenericDictionary : IDictionary<string, string>
{
    public string this[string key]
    {
        get { return null; }
        set { }
    }
 
    public int Count => 0;
    public bool IsReadOnly => true;
    public ICollection<string> Keys => null;
    public ICollection<string> Values => null;
    public void Add(string key, string value) { }
    public void Add(KeyValuePair<string, string> item) { }
    public void Clear() { }
    public void CopyTo(KeyValuePair<string, string>[] array, int index) { }
 
    public bool Remove(string key) 
    { 
        return false;
    }
 
    public bool Remove(KeyValuePair<string, string> item) 
    { 
        return false;
    }
 
    public bool TryGetValue(string key, out string value)
    {
        value = null;
        return false;
    }
 
    public bool Contains(KeyValuePair<string, string> item)
    {
        return false;
    }
 
    public bool ContainsKey(string key)
    {
        return false;
    }
 
    public IEnumerator<KeyValuePair<string, string>> GetEnumerator()
    {
        return null;
    }
 
    IEnumerator IEnumerable.GetEnumerator()
    {
        return null;
    }
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeImplementsGenericIDictionaryAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Collections
Imports System.Collections.Generic
 
Public Class MyGenericDictionary
    Implements IDictionary(Of String, String)
 
    Default Public Property Item(key As String) As String Implements IDictionary(Of String, String).Item
        Get
            Return Nothing
        End Get
        Set(value As String)
        End Set
    End Property
 
    Public ReadOnly Property Count As Integer Implements ICollection(Of KeyValuePair(Of String, String)).Count
        Get
            Return 0
        End Get
    End Property
 
    Public ReadOnly Property IsReadOnly As Boolean Implements ICollection(Of KeyValuePair(Of String, String)).IsReadOnly
        Get
            Return True
        End Get
    End Property
 
    Public ReadOnly Property Keys As ICollection(Of String) Implements IDictionary(Of String, String).Keys
        Get
            Return Nothing
        End Get
    End Property
 
    Public ReadOnly Property Values As ICollection(Of String) Implements IDictionary(Of String, String).Values
        Get
            Return Nothing
        End Get
    End Property
 
    Public Sub Add(key As String, value As String) Implements IDictionary(Of String, String).Add
    End Sub
 
    Public Sub Add(item As KeyValuePair(Of String, String)) Implements ICollection(Of KeyValuePair(Of String, String)).Add
    End Sub
 
    Public Sub Clear() Implements ICollection(Of KeyValuePair(Of String, String)).Clear
    End Sub
 
    Public Sub CopyTo(array() As KeyValuePair(Of String, String), arrayIndex As Integer) Implements ICollection(Of KeyValuePair(Of String, String)).CopyTo
    End Sub
 
    Public Function Remove(key As String) As Boolean Implements IDictionary(Of String, String).Remove
        Return False
    End Function
 
    Public Function Remove(item As KeyValuePair(Of String, String)) As Boolean Implements ICollection(Of KeyValuePair(Of String, String)).Remove
        Return False
    End Function
 
    Public Function TryGetValue(key As String, ByRef value As String) As Boolean Implements IDictionary(Of String, String).TryGetValue
        Return False
    End Function
 
    Public Function Contains(item As KeyValuePair(Of String, String)) As Boolean Implements ICollection(Of KeyValuePair(Of String, String)).Contains
        Return False
    End Function
 
    Public Function ContainsKey(key As String) As Boolean Implements IDictionary(Of String, String).ContainsKey
        Return False
    End Function
 
    Public Function GetEnumerator() As IEnumerator(Of KeyValuePair(Of String, String)) Implements IEnumerable(Of KeyValuePair(Of String, String)).GetEnumerator
        Return Nothing
    End Function
 
    Private Function IEnumerable_GetEnumerator() As IEnumerator Implements IEnumerable.GetEnumerator
        Return Nothing
    End Function
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeImplementsNonGenericIDictionaryAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System;
using System.Collections;
using System.Runtime.Serialization;
 
public class MyNonGenericDictionary : IDictionary
{
    protected MyNonGenericDictionary(SerializationInfo info, StreamingContext context) { }
 
    public object this[object key]
    {
        get { return null; }
        set { }
    }
 
    public int Count => 0;
    public bool IsFixedSize => true;
    public bool IsReadOnly => true;
    public bool IsSynchronized => false;
    public ICollection Keys => null;
    public object SyncRoot => null;
    public ICollection Values => null;
    public void Add(object key, object value) { }
    public void Clear() { }
    public void CopyTo(Array array, int index) { }
    public void Remove(object key) { }
 
    public bool Contains(object key)
    {
        return false;
    }
 
    public IDictionaryEnumerator GetEnumerator()
    {
        return null;
    }
 
    IEnumerator IEnumerable.GetEnumerator()
    {
        return null;
    }
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeImplementsNonGenericIDictionaryAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System
Imports System.Collections
Imports System.Runtime.Serialization
 
Public Class MyNonGenericDictionary
    Implements IDictionary
 
    Protected Sub New(info As SerializationInfo, context As StreamingContext)
    End Sub
 
    Public ReadOnly Property Count As Integer Implements ICollection.Count
        Get
            Return 0
        End Get
    End Property
 
    Public ReadOnly Property IsFixedSize As Boolean Implements IDictionary.IsFixedSize
        Get
            Return True
        End Get
    End Property
 
    Public ReadOnly Property IsReadOnly As Boolean Implements IDictionary.IsReadOnly
        Get
            Return True
        End Get
    End Property
 
    Public ReadOnly Property IsSynchronized As Boolean Implements ICollection.IsSynchronized
        Get
            Return False
        End Get
    End Property
 
    Default Public Property Item(key As Object) As Object Implements IDictionary.Item
        Get
            Return Nothing
        End Get
        Set(value As Object)
        End Set
    End Property
 
    Public ReadOnly Property Keys As ICollection Implements IDictionary.Keys
        Get
            Return Nothing
        End Get
    End Property
 
    Public ReadOnly Property SyncRoot As Object Implements ICollection.SyncRoot
        Get
            Return Nothing
        End Get
    End Property
 
    Public ReadOnly Property Values As ICollection Implements IDictionary.Values
        Get
            Return Nothing
        End Get
    End Property
 
    Public Sub Add(key As Object, value As Object) Implements IDictionary.Add
    End Sub
 
    Public Sub Clear() Implements IDictionary.Clear
    End Sub
 
    Public Sub CopyTo(array As Array, index As Integer) Implements ICollection.CopyTo
    End Sub
 
    Public Sub Remove(key As Object) Implements IDictionary.Remove
    End Sub
 
    Public Function Contains(key As Object) As Boolean Implements IDictionary.Contains
        Return False
    End Function
 
    Public Function GetEnumerator() As IDictionaryEnumerator Implements IDictionary.GetEnumerator
        Return Nothing
    End Function
 
    Private Function IEnumerable_GetEnumerator() As IEnumerator Implements IEnumerable.GetEnumerator
        Return Nothing
    End Function
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromGenericDictionaryAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System;
using System.Collections.Generic;
using System.Runtime.Serialization;
 
[Serializable]
public class MyGenericDictionary<K, V> : Dictionary<K, V>
{
    protected MyGenericDictionary(SerializationInfo info, StreamingContext context)
        : base(info, context)
    {
    }
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromGenericDictionaryAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System
Imports System.Collections.Generic
Imports System.Runtime.Serialization
 
<Serializable>
Public Class MyGenericDictionary(Of K, V)
    Inherits Dictionary(Of K, V)
    Protected Sub New(info As SerializationInfo, context As StreamingContext)
        MyBase.New(info, context)
    End Sub
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromPartiallyInstantiatedGenericDictionaryAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System;
using System.Collections.Generic;
using System.Runtime.Serialization;
 
[Serializable]
public class MyStringDictionary<V> : Dictionary<string, V>
{
    protected MyStringDictionary(SerializationInfo info, StreamingContext context)
        : base(info, context)
    {
    }
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromPartiallyInstantiatedGenericDictionaryAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System
Imports System.Collections.Generic
Imports System.Runtime.Serialization
 
<Serializable>
Public Class MyStringDictionary(Of V)
    Inherits Dictionary(Of String, V)
    Protected Sub New(info As SerializationInfo, context As StreamingContext)
        MyBase.New(info, context)
    End Sub
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromFullyInstantiatedGenericDictionaryAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System;
using System.Collections.Generic;
using System.Runtime.Serialization;
 
[Serializable]
public class MyStringToIntDictionary : Dictionary<string, int>
{
    protected MyStringToIntDictionary(SerializationInfo info, StreamingContext context)
        : base(info, context)
    {
    }
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromFullyInstantiatedGenericDictionaryAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System
Imports System.Collections.Generic
Imports System.Runtime.Serialization
 
<Serializable>
Public Class MyStringToIntDictionary
    Inherits Dictionary(Of String, Integer)
    Protected Sub New(info As SerializationInfo, context As StreamingContext)
        MyBase.New(info, context)
    End Sub
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeDoesNotDeriveFromCollectionAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBadCollection {}",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadCollection",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CollectionSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeDoesNotDeriveFromCollectionAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBadCollection
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadCollection",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CollectionSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeImplementsNonGenericICollectionAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.Collections;
 
public class MyNonGenericCollection : ICollection
{
    public int Count => 0;
    public bool IsSynchronized => true;
    public object SyncRoot => null;
    public void CopyTo(System.Array array, int index) { }
 
    public IEnumerator GetEnumerator()
    {
        return null;
    }
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeImplementsNonGenericICollectionAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Collections
 
Public Class MyNonGenericCollection
    Implements ICollection
 
    Public ReadOnly Property Count As Integer Implements ICollection.Count
        Get
            Return 0
        End Get
    End Property
 
    Public ReadOnly Property IsSynchronized As Boolean Implements ICollection.IsSynchronized
        Get
            Return False
        End Get
    End Property
 
    Public ReadOnly Property SyncRoot As Object Implements ICollection.SyncRoot
        Get
            Return Nothing
        End Get
    End Property
 
    Public Sub CopyTo(array As System.Array, index As Integer) Implements ICollection.CopyTo
    End Sub
 
    Public Function GetEnumerator() As IEnumerator Implements IEnumerable.GetEnumerator
        Return Nothing
    End Function
End Class
");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeImplementsNonGenericIEnumerableAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.Collections;
 
public class MyEnumerableCollection : IEnumerable
{
    public IEnumerator GetEnumerator()
    {
        return null;
    }
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeImplementsNonGenericIEnumerableAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Collections
 
Public Class MyEnumerableCollection
    Implements IEnumerable
 
    Public Function GetEnumerator() As IEnumerator Implements IEnumerable.GetEnumerator
        Return Nothing
    End Function
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeImplementsInstantiatedGenericICollectionAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.Collections;
using System.Collections.Generic;
 
public class MyIntCollection : ICollection<int>
{
    public int Count => 0;
    public bool IsReadOnly => true;
 
    public void Add(int item) { }
    public void Clear() { }
 
    public bool Contains(int item)
    {
        return false;
    }
 
    public void CopyTo(int[] array, int arrayIndex) { }
 
    public IEnumerator<int> GetEnumerator()
    {
        return null;
    }
 
    public bool Remove(int item)
    {
        return false;
    }
 
    IEnumerator IEnumerable.GetEnumerator()
    {
        return null;
    }
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeImplementsInstantiatedGenericICollectionAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Collections
Imports System.Collections.Generic
 
Public Class MyIntCollection
    Implements ICollection(Of Integer)
 
    Public ReadOnly Property Count As Integer Implements ICollection(Of Integer).Count
        Get
            Return 0
        End Get
    End Property
 
    Public ReadOnly Property IsReadOnly As Boolean Implements ICollection(Of Integer).IsReadOnly
        Get
            Return True
        End Get
    End Property
 
    Public Sub Add(item As Integer) Implements ICollection(Of Integer).Add
    End Sub
 
    Public Sub Clear() Implements ICollection(Of Integer).Clear
    End Sub
 
    Public Sub CopyTo(array() As Integer, arrayIndex As Integer) Implements ICollection(Of Integer).CopyTo
    End Sub
 
    Public Function Contains(item As Integer) As Boolean Implements ICollection(Of Integer).Contains
        Return False
    End Function
 
    Public Function GetEnumerator() As IEnumerator(Of Integer) Implements IEnumerable(Of Integer).GetEnumerator
        Return Nothing
    End Function
 
    Public Function Remove(item As Integer) As Boolean Implements ICollection(Of Integer).Remove
        Return False
    End Function
 
    Private Function IEnumerable_GetEnumerator() As IEnumerator Implements IEnumerable.GetEnumerator
        Return Nothing
    End Function
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromNonGenericQueueAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.Collections;
 
public class MyNonGenericQueue : Queue { }");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromNonGenericQueueAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Collections
 
Public Class MyNonGenericQueue
    Inherits Queue
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromGenericQueueAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.Collections.Generic;
 
public class MyGenericQueue<T> : Queue<T> { }");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromGenericQueueAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Collections.Generic
 
Public Class MyGenericQueue(Of T)
    Inherits Queue(Of T)
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromInstantiatedGenericQueueAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.Collections.Generic;
 
public class MyIntQueue : Queue<int> { }");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromInstantiatedGenericQueueAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Collections.Generic
 
Public Class MyIntQueue
    Inherits Queue(Of Integer)
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeDoesNotDeriveFromQueueAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBadQueue { }",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadQueue",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.QueueSuffix)
                );
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeDoesNotDeriveFromQueueAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBadQueue
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadQueue",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.QueueSuffix)
                );
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromNonGenericStackAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.Collections;
 
public class MyNonGenericStack : Stack { }");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromNonGenericStackAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Collections
 
Public Class MyNonGenericStack
    Inherits Stack
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromGenericStackAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.Collections.Generic;
 
public class MyGenericStack<T> : Stack<T> { }");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromGenericStackAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Collections.Generic
 
Public Class MyGenericStack(Of T)
    Inherits Stack(Of T)
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeDerivesFromInstantiatedGenericStackAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System.Collections.Generic;
 
public class MyIntStack : Stack<int> { }");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeDerivesFromInstantiatedGenericStackAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System.Collections.Generic
 
Public Class MyIntStack
    Inherits Stack(Of Integer)
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeDoesNotDeriveFromStackAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBadStack { }",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadStack",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.StackSuffix)
                );
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeDoesNotDeriveFromStackAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBadStack
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadStack",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.StackSuffix)
                );
        }
 
        // MSDN says that DataSet and DataTable can be called "Collection",
        // but FxCop disagrees.
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeDerivesFromDataSetAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System;
using System.Data;
 
[Serializable]
public class MyBadDataSetCollection : DataSet { }",
                GetCSharpResultAt(
                    5, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadDataSetCollection",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CollectionSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeDerivesFromDataSetAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System
Imports System.Data
 
<Serializable>
Public Class MyBadDataSetCollection
    Inherits DataSet
End Class",
                GetBasicResultAt(
                    5, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadDataSetCollection",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CollectionSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeDerivesFromDataTableAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System;
using System.Data;
 
[Serializable]
public class MyBadDataTableCollection : DataTable { }",
                GetCSharpResultAt(
                    5, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadDataTableCollection",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CollectionSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeDerivesFromDataTableAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System
Imports System.Data
 
<Serializable>
Public Class MyBadDataTableCollection
    Inherits DataTable
End Class",
                GetBasicResultAt(
                    5, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule,
                    "MyBadDataTableCollection",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CollectionSuffix));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeNameEndsWithExAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClassEx { }",
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyClassEx"));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeNameEndsWithExAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyClassEx
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyClassEx"));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_TypeNameNameIsExAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class Ex { }");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_TypeNameNameIsExAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class Ex
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_TypeNameEndsWithNewAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClassNew { }",
 
                GetCSharpResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.NewSuffix,
                    "MyClassNew"));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_TypeNameEndsWithNewAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyClassNew
End Class",
                GetBasicResultAt(
                    1, 14,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.NewSuffix,
                    "MyClassNew"));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_MethodNameEndsWithNewAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClass
{
    public void MyMethodNew() { }
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_MethodNameEndsWithNewAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class [MyClass]
    Public Sub MyMethodNew()
    End Sub
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_MethodNameEndsWithNewAndMethodNameWithoutNewExistsInSameClassAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBaseClass
{
    public void MyMethod() { }
    public void MyMethodNew() { }
}",
                GetCSharpResultAt(
                    4, 17,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.NewSuffix,
                    "MyMethodNew"));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_MethodNameEndsWithNewAndMethodNameWithoutNewExistsInSameClassAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBaseClass
    Public Sub MyMethod()
    End Sub
 
    Public Sub MyMethodNew()
    End Sub
End Class",
                GetBasicResultAt(
                    5, 16,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.NewSuffix,
                    "MyMethodNew"));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_MethodNameEndsWithNewAndMethodNameWithoutNewExistsInAncestorClassAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBaseClass
{
    public void MyMethod() { }
}
 
public class MyDerivedClass : MyBaseClass
{
}
 
public class MyClass : MyDerivedClass
{
    public void MyMethodNew() { }
}",
                GetCSharpResultAt(
                    12, 17,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.NewSuffix,
                    "MyMethodNew"));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_MethodNameEndsWithNewAndMethodNameWithoutNewExistsInAncestorClassAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBaseClass
    Public Sub MyMethod()
    End Sub
End Class
 
Public Class MyDerivedClass
    Inherits MyBaseClass
End Class
 
Public Class [MyClass]
    Inherits MyDerivedClass
 
    Public Sub MyMethodNew()
    End Sub
End Class",
                GetBasicResultAt(
                    13, 16,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.NewSuffix,
                    "MyMethodNew"));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_MethodNameEndingWithNewImplementsInterfaceMethodAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public interface MyBaseInterface
{
    void MyMethodNew();
}
 
public interface MyDerivedInterface : MyBaseInterface
{
}
 
public class MyClass : MyDerivedInterface
{
    public void MyMethodNew() { }
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_MethodNameEndsWithNewAndMethodNameWithoutNewExistsInImplementedInterfaceAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Interface MyBaseInterface
    Sub MyMethodNew()
End Interface
 
Public Interface MyDerivedInterface
    Inherits MyBaseInterface
End Interface
 
Public Class [MyClass]
    Implements MyDerivedInterface
    Public Sub MyMethodNew() Implements MyBaseInterface.MyMethodNew
    End Sub
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_MethodNameEndsWithExAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClass
{
    public void MyMethodEx() { }
}",
                GetCSharpResultAt(
                    3, 17,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyMethodEx"));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_MethodNameEndsWithExAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class [MyClass]
    Public Sub MyMethodEx()
    End Sub
End Class",
                GetBasicResultAt(
                    2, 16,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyMethodEx"));
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_PrivateMethodNameEndsWithExAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClass
{
    private void MyMethodEx() { }
}");
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_PrivateMethodNameEndsWithExAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class [MyClass]
    Private Sub MyMethodEx()
    End Sub
End Class");
        }
 
        [Fact]
        public async Task CA1711_CSharp_NoDiagnostic_OverriddenMethodNameEndsWithExAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyBaseClass
{
    public virtual void MyMethodEx() { }
}
 
public class MyClass : MyBaseClass
{
    public override void MyMethodEx() { }
}",
                // Diagnostic for the base class method, but none for the override.
                GetCSharpResultAt(
                    3, 25,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyMethodEx"));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_MethodNameEndingWithExImplementsInterfaceMethodAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public interface MyBaseInterface
{
    void MyMethodEx();
}
 
public interface MyDerivedInterface : MyBaseInterface
{
}
 
public class MyClass : MyDerivedInterface
{
    public void MyMethodEx() { }
}",
                // Diagnostic for the interface method, but none for the implementation.
                GetCSharpResultAt(
                    3, 10,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyMethodEx"));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_MethodNameEndingWithExImplementsInterfaceMethodAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Interface MyBaseInterface
    Sub MyMethodEx()
End Interface
 
Public Interface MyDerivedInterface
    Inherits MyBaseInterface
End Interface
 
Public Class [MyClass]
    Implements MyDerivedInterface
    Public Sub MyMethodEx() Implements MyBaseInterface.MyMethodEx
    End Sub
End Class",
                // Diagnostic for the interface method, but none for the implementation.
                GetBasicResultAt(
                    2, 9,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyMethodEx"));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_MethodNameEndsWithImplAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClass
{
    public void MyMethodImpl() { }
}",
                GetCSharpResultAt(
                    3, 17,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberWithAlternateRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ImplSuffix,
                    "MyMethodImpl",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CoreSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_MethodNameEndsWithImplAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class [MyClass]
    Public Sub MyMethodImpl()
    End Sub
End Class",
                GetBasicResultAt(
                    2, 16,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberWithAlternateRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ImplSuffix,
                    "MyMethodImpl",
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.CoreSuffix));
        }
 
        [Fact]
        public async Task CA1711_Basic_NoDiagnostic_OverriddenMethodNameEndsWithExAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class MyBaseClass
    Public Overridable Sub MyMethodEx()
    End Sub
End Class
 
Public Class [MyClass]
    Inherits MyBaseClass
 
    Public Overrides Sub MyMethodEx()
    End Sub
End Class",
                // Diagnostic for the base class method, but none for the override.
                GetBasicResultAt(
                    2, 28,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyMethodEx"));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_EventNameEndsWithExAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"using System;
 
public class MyClass
{
    public delegate void EventCallback(object sender, EventArgs e);
    public event EventCallback MyEventEx;
}",
                GetCSharpResultAt(
                    6, 32,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyEventEx"));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_EventNameEndsWithExAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Imports System
 
Public Class [MyClass]
    Public Delegate Sub EventCallback(sender As Object, e As EventArgs)
    Public Event MyEventEx As EventCallback
End Class",
                GetBasicResultAt(
                    5, 18,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyEventEx"));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_PropertyNameEndsWithExAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClass
{
    public int MyPropertyEx { get; set; }
}",
                GetCSharpResultAt(
                    3, 16,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyPropertyEx"));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_PropertyNameEndsWithExAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class [MyClass]
    Public Property MyPropertyEx As Integer
        Get
            Return 0
        End Get
        Set(value As Integer)
        End Set
    End Property
End Class",
                GetBasicResultAt(
                    2, 21,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyPropertyEx"));
        }
 
        [Fact]
        public async Task CA1711_CSharp_Diagnostic_FieldNameEndsWithExAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(
@"public class MyClass
{
    public int MyFieldEx;
}",
                GetCSharpResultAt(
                    3, 16,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyFieldEx"));
        }
 
        [Fact]
        public async Task CA1711_Basic_Diagnostic_FieldNameEndsWithExAsync()
        {
            await VerifyVB.VerifyAnalyzerAsync(
@"Public Class [MyClass]
    Public MyFieldEx As Integer
End Class",
                GetBasicResultAt(
                    2, 12,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.MemberNewerVersionRule,
                    IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.ExSuffix,
                    "MyFieldEx"));
        }
 
        [Fact]
        public async Task CA1711_EnumFlagSuffix_DiagnosticAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(@"
public enum SomeEnumFlag
{
    X,
}",
                GetCSharpResultAt(2, 13, IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule, "SomeEnumFlag", IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.FlagSuffix));
 
            await VerifyVB.VerifyAnalyzerAsync(@"
Public Enum SomeEnumFlag
    X
End Enum",
                GetCSharpResultAt(2, 13, IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule, "SomeEnumFlag", IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.FlagSuffix));
        }
 
        [Fact]
        public async Task CA1711_EnumFlagsSuffix_DiagnosticAsync()
        {
            await VerifyCS.VerifyAnalyzerAsync(@"
public enum SomeEnumFlags
{
    X,
}",
                GetCSharpResultAt(2, 13, IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule, "SomeEnumFlags", IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.FlagsSuffix));
 
            await VerifyVB.VerifyAnalyzerAsync(@"
Public Enum SomeEnumFlags
    X
End Enum",
                GetCSharpResultAt(2, 13, IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.TypeNoAlternateRule, "SomeEnumFlags", IdentifiersShouldNotHaveIncorrectSuffixAnalyzer.FlagsSuffix));
        }
 
        [Fact]
        public async Task CA1711_AllowedSuffixes_NoDiagnosticAsync()
        {
            const string editorConfigText = "dotnet_code_quality.CA1711.allowed_suffixes = Attribute|Flag";
 
            await new VerifyCS.Test
            {
                TestState =
                {
                    Sources =
                    {
                        @"
public enum MyFlag {}
 
public class MyAttribute {}",
                    },
                    AnalyzerConfigFiles = { ("/.editorconfig", $@"root = true
 
[*]
{editorConfigText}
"), },
                },
            }.RunAsync();
 
            await new VerifyVB.Test
            {
                TestState =
                {
                    Sources =
                    {
                        @"
Public Enum MyFlag
    A
End Enum
 
Public Class MyAttribute
End Class",
                    },
                    AnalyzerConfigFiles = { ("/.editorconfig", $@"root = true
 
[*]
{editorConfigText}
"), },
                },
            }.RunAsync();
        }
 
        private static DiagnosticResult GetCSharpResultAt(int line, int column, DiagnosticDescriptor rule, params string[] arguments)
#pragma warning disable RS0030 // Do not use banned APIs
            => VerifyCS.Diagnostic(rule)
                .WithLocation(line, column)
#pragma warning restore RS0030 // Do not use banned APIs
                .WithArguments(arguments);
 
        private static DiagnosticResult GetBasicResultAt(int line, int column, DiagnosticDescriptor rule, params string[] arguments)
#pragma warning disable RS0030 // Do not use banned APIs
            => VerifyVB.Diagnostic(rule)
                .WithLocation(line, column)
#pragma warning restore RS0030 // Do not use banned APIs
                .WithArguments(arguments);
    }
}