Browse Source

Merge pull request #3164 from yzdeveloper/feature/AnalyzerScope

Analyzers/AnalyzerScope loops endlessly when analysing public inner c…
natural-type-lambdas-methods
Siegfried Pammer 1 year ago committed by GitHub
parent
commit
e375bd788a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
  1. 67
      ILSpy.Tests/Analyzers/AnalyzerScopeTests.cs
  2. 1
      ILSpy.Tests/ILSpy.Tests.csproj
  3. 1
      ILSpy/Analyzers/AnalyzerScope.cs

67
ILSpy.Tests/Analyzers/AnalyzerScopeTests.cs

@ -0,0 +1,67 @@ @@ -0,0 +1,67 @@
// Copyright (c) 2024 Yuriy Zatuchnyy
//
// Permission is hereby granted, free of charge, to any person obtaining a copy of this
// software and associated documentation files (the "Software"), to deal in the Software
// without restriction, including without limitation the rights to use, copy, modify, merge,
// publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons
// to whom the Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in all copies or
// substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
// INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE
// FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
using System.Linq;
using System.Threading.Tasks;
using ICSharpCode.Decompiler;
using ICSharpCode.Decompiler.CSharp.Resolver;
using ICSharpCode.Decompiler.Metadata;
using ICSharpCode.Decompiler.TypeSystem;
using ICSharpCode.ILSpy.Analyzers;
using NUnit.Framework;
namespace ICSharpCode.ILSpy.Tests.Analyzers
{
[TestFixture]
public class AnalyzerScopeTests
{
public class TestClass
{
}
[Test]
public void WhenPublicNestedClass_ThenNotInfiniteLoop()
{
// Given
ILSpyX.AssemblyList assemblyList = new ILSpyX.AssemblyList();
var file = new PEFile(this.GetType().Assembly.Location);
var td = file.Metadata.TypeDefinitions.First(td => td.GetFullTypeName(file.Metadata).Name == nameof(TestClass));
Decompiler.Metadata.IAssemblyResolver assemblyResolver = new UniversalAssemblyResolver(null, false, null);
ICompilation compilation = new DecompilerTypeSystem(file, assemblyResolver);
ITypeResolveContext context = new CSharpResolver(compilation);
var module = ((IModuleReference)file).Resolve(context) as MetadataModule;
IEntity entity = module.GetDefinition(td);
// When
var task = Task.Run(() => {
var target = new AnalyzerScope(assemblyList, entity);
});
var result = Task.WaitAny(new[] { task, Task.Delay(500) }); // 0.5 seconds
// Then
Assert.That(result == 0, "The constructor should complete in less than 10 seconds");
}
}
}

1
ILSpy.Tests/ILSpy.Tests.csproj

@ -34,6 +34,7 @@ @@ -34,6 +34,7 @@
</PropertyGroup>
<ItemGroup>
<Compile Include="Analyzers\AnalyzerScopeTests.cs" />
<Compile Include="Analyzers\MemberImplementsInterfaceAnalyzerTests.cs" />
<Compile Include="Analyzers\MethodUsesAnalyzerTests.cs" />
<Compile Include="Analyzers\TestCases\MainAssembly.cs" />

1
ILSpy/Analyzers/AnalyzerScope.cs

@ -122,6 +122,7 @@ namespace ICSharpCode.ILSpy.Analyzers @@ -122,6 +122,7 @@ namespace ICSharpCode.ILSpy.Analyzers
while (typeScope != null && !accessibility.LessThanOrEqual(Accessibility.Private))
{
accessibility = accessibility.Intersect(typeScope.Accessibility);
prevTypeScope = typeScope;
typeScope = prevTypeScope.DeclaringTypeDefinition;
}
if (typeScope == null)

Loading…
Cancel
Save