-
Notifications
You must be signed in to change notification settings - Fork 510
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add tests for ForEachVariableStatementSyntaxWrapper
- Loading branch information
1 parent
ef1f91c
commit c44b4ba
Showing
5 changed files
with
443 additions
and
0 deletions.
There are no files selected for viewing
11 changes: 11 additions & 0 deletions
11
...Cop.Analyzers.Test.CSharp10/Lightup/ForEachVariableStatementSyntaxWrapperTestsCSharp10.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
// Copyright (c) Tunnel Vision Laboratories, LLC. All Rights Reserved. | ||
// Licensed under the MIT License. See LICENSE in the project root for license information. | ||
|
||
namespace StyleCop.Analyzers.Test.CSharp10.Lightup | ||
{ | ||
using StyleCop.Analyzers.Test.CSharp9.Lightup; | ||
|
||
public class ForEachVariableStatementSyntaxWrapperTestsCSharp10 : ForEachVariableStatementSyntaxWrapperTestsCSharp9 | ||
{ | ||
} | ||
} |
11 changes: 11 additions & 0 deletions
11
...Cop.Analyzers.Test.CSharp11/Lightup/ForEachVariableStatementSyntaxWrapperTestsCSharp11.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
// Copyright (c) Tunnel Vision Laboratories, LLC. All Rights Reserved. | ||
// Licensed under the MIT License. See LICENSE in the project root for license information. | ||
|
||
namespace StyleCop.Analyzers.Test.CSharp11.Lightup | ||
{ | ||
using StyleCop.Analyzers.Test.CSharp10.Lightup; | ||
|
||
public class ForEachVariableStatementSyntaxWrapperTestsCSharp11 : ForEachVariableStatementSyntaxWrapperTestsCSharp10 | ||
{ | ||
} | ||
} |
203 changes: 203 additions & 0 deletions
203
...ers/StyleCop.Analyzers.Test.CSharp7/Lightup/ForEachVariableStatementSyntaxWrapperTests.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,203 @@ | ||
// Copyright (c) Tunnel Vision Laboratories, LLC. All Rights Reserved. | ||
// Licensed under the MIT License. See LICENSE in the project root for license information. | ||
|
||
namespace StyleCop.Analyzers.Test.CSharp7.Lightup | ||
{ | ||
using System; | ||
using Microsoft.CodeAnalysis; | ||
using Microsoft.CodeAnalysis.CSharp; | ||
using Microsoft.CodeAnalysis.CSharp.Syntax; | ||
using StyleCop.Analyzers.Helpers; | ||
using StyleCop.Analyzers.Lightup; | ||
using Xunit; | ||
|
||
public class ForEachVariableStatementSyntaxWrapperTests | ||
{ | ||
[Fact] | ||
public void TestNull() | ||
{ | ||
var syntaxNode = default(SyntaxNode); | ||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
Assert.Null(wrapper.SyntaxNode); | ||
Assert.Throws<NullReferenceException>(() => wrapper.AwaitKeyword); | ||
Assert.Throws<NullReferenceException>(() => wrapper.ForEachKeyword); | ||
Assert.Throws<NullReferenceException>(() => wrapper.OpenParenToken); | ||
Assert.Throws<NullReferenceException>(() => wrapper.Variable); | ||
Assert.Throws<NullReferenceException>(() => wrapper.InKeyword); | ||
Assert.Throws<NullReferenceException>(() => wrapper.Expression); | ||
Assert.Throws<NullReferenceException>(() => wrapper.CloseParenToken); | ||
Assert.Throws<NullReferenceException>(() => wrapper.Statement); | ||
Assert.Throws<NullReferenceException>(() => wrapper.WithAwaitKeyword(SyntaxFactory.Token(SyntaxKind.AwaitKeyword))); | ||
Assert.Throws<NullReferenceException>(() => wrapper.WithForEachKeyword(SyntaxFactory.Token(SyntaxKind.ForEachKeyword))); | ||
Assert.Throws<NullReferenceException>(() => wrapper.WithOpenParenToken(SyntaxFactory.Token(SyntaxKind.OpenParenToken))); | ||
Assert.Throws<NullReferenceException>(() => wrapper.WithVariable(SyntaxFactory.LiteralExpression(SyntaxKind.NullLiteralExpression))); | ||
Assert.Throws<NullReferenceException>(() => wrapper.WithInKeyword(SyntaxFactory.Token(SyntaxKind.InKeyword))); | ||
Assert.Throws<NullReferenceException>(() => wrapper.WithExpression(SyntaxFactory.LiteralExpression(SyntaxKind.NullLiteralExpression))); | ||
Assert.Throws<NullReferenceException>(() => wrapper.WithCloseParenToken(SyntaxFactory.Token(SyntaxKind.CloseParenToken))); | ||
Assert.Throws<NullReferenceException>(() => wrapper.WithStatement(SyntaxFactory.EmptyStatement())); | ||
} | ||
|
||
[Fact] | ||
public void TestWrapperIdentity() | ||
{ | ||
var syntaxNode = this.CreateForEachVariableStatement(); | ||
Assert.True(syntaxNode.IsKind(SyntaxKind.ForEachVariableStatement)); | ||
|
||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
Assert.Same(syntaxNode, wrapper.SyntaxNode); | ||
} | ||
|
||
[Fact] | ||
public void TestAwaitKeyword() | ||
{ | ||
var syntaxNode = this.CreateForEachVariableStatement(); | ||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
Assert.Equal(default, wrapper.AwaitKeyword); | ||
|
||
Assert.Throws<NotSupportedException>(() => wrapper.WithAwaitKeyword(SyntaxFactory.Token(SyntaxKind.AwaitKeyword))); | ||
} | ||
|
||
[Fact] | ||
public void TestForEachKeyword() | ||
{ | ||
var syntaxNode = this.CreateForEachVariableStatement(); | ||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
Assert.Equal(syntaxNode.ForEachKeyword, wrapper.ForEachKeyword); | ||
|
||
wrapper = wrapper.WithForEachKeyword(SpacingExtensions.WithoutTrivia(SyntaxFactory.Token(SyntaxKind.ForEachKeyword))); | ||
Assert.NotNull(wrapper.SyntaxNode); | ||
Assert.NotSame(syntaxNode, wrapper.SyntaxNode); | ||
Assert.False(syntaxNode.ForEachKeyword.IsEquivalentTo(wrapper.ForEachKeyword)); | ||
} | ||
|
||
[Fact] | ||
public void TestOpenParenToken() | ||
{ | ||
var syntaxNode = this.CreateForEachVariableStatement(); | ||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
Assert.Equal(syntaxNode.OpenParenToken, wrapper.OpenParenToken); | ||
|
||
wrapper = wrapper.WithOpenParenToken(SpacingExtensions.WithoutTrivia(SyntaxFactory.Token(SyntaxKind.OpenParenToken))); | ||
Assert.NotNull(wrapper.SyntaxNode); | ||
Assert.NotSame(syntaxNode, wrapper.SyntaxNode); | ||
Assert.False(syntaxNode.OpenParenToken.IsEquivalentTo(wrapper.OpenParenToken)); | ||
} | ||
|
||
[Fact] | ||
public void TestVariable() | ||
{ | ||
var syntaxNode = this.CreateForEachVariableStatement(); | ||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
Assert.Same(syntaxNode.Variable, wrapper.Variable); | ||
|
||
wrapper = wrapper.WithVariable(SyntaxFactory.LiteralExpression(SyntaxKind.NumericLiteralExpression, SyntaxFactory.Literal(0))); | ||
Assert.NotNull(wrapper.SyntaxNode); | ||
Assert.NotSame(syntaxNode, wrapper.SyntaxNode); | ||
Assert.NotSame(syntaxNode.Variable, wrapper.Variable); | ||
Assert.False(syntaxNode.Variable.IsEquivalentTo(wrapper.Variable)); | ||
} | ||
|
||
[Fact] | ||
public void TestInKeyword() | ||
{ | ||
var syntaxNode = this.CreateForEachVariableStatement(); | ||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
Assert.Equal(syntaxNode.InKeyword, wrapper.InKeyword); | ||
|
||
wrapper = wrapper.WithInKeyword(SpacingExtensions.WithoutTrivia(SyntaxFactory.Token(SyntaxKind.InKeyword))); | ||
Assert.NotNull(wrapper.SyntaxNode); | ||
Assert.NotSame(syntaxNode, wrapper.SyntaxNode); | ||
Assert.False(syntaxNode.InKeyword.IsEquivalentTo(wrapper.InKeyword)); | ||
} | ||
|
||
[Fact] | ||
public void TestExpression() | ||
{ | ||
var syntaxNode = this.CreateForEachVariableStatement(); | ||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
Assert.Same(syntaxNode.Expression, wrapper.Expression); | ||
|
||
wrapper = wrapper.WithExpression(SyntaxFactory.LiteralExpression(SyntaxKind.NumericLiteralExpression, SyntaxFactory.Literal(0))); | ||
Assert.NotNull(wrapper.SyntaxNode); | ||
Assert.NotSame(syntaxNode, wrapper.SyntaxNode); | ||
Assert.NotSame(syntaxNode.Expression, wrapper.Expression); | ||
Assert.False(syntaxNode.Expression.IsEquivalentTo(wrapper.Expression)); | ||
} | ||
|
||
[Fact] | ||
public void TestCloseParenToken() | ||
{ | ||
var syntaxNode = this.CreateForEachVariableStatement(); | ||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
Assert.Equal(syntaxNode.CloseParenToken, wrapper.CloseParenToken); | ||
|
||
wrapper = wrapper.WithCloseParenToken(SpacingExtensions.WithoutTrivia(SyntaxFactory.Token(SyntaxKind.CloseParenToken))); | ||
Assert.NotNull(wrapper.SyntaxNode); | ||
Assert.NotSame(syntaxNode, wrapper.SyntaxNode); | ||
Assert.False(syntaxNode.CloseParenToken.IsEquivalentTo(wrapper.CloseParenToken)); | ||
} | ||
|
||
[Fact] | ||
public void TestStatement() | ||
{ | ||
var syntaxNode = this.CreateForEachVariableStatement(); | ||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
Assert.Same(syntaxNode.Statement, wrapper.Statement); | ||
|
||
wrapper = wrapper.WithStatement(SyntaxFactory.Block()); | ||
Assert.NotNull(wrapper.SyntaxNode); | ||
Assert.NotSame(syntaxNode, wrapper.SyntaxNode); | ||
Assert.NotSame(syntaxNode.Statement, wrapper.Statement); | ||
Assert.False(syntaxNode.Statement.IsEquivalentTo(wrapper.Statement)); | ||
} | ||
|
||
[Fact] | ||
public void TestIsInstance() | ||
{ | ||
Assert.False(ForEachVariableStatementSyntaxWrapper.IsInstance(null)); | ||
Assert.False(ForEachVariableStatementSyntaxWrapper.IsInstance(SyntaxFactory.LiteralExpression(SyntaxKind.NullLiteralExpression))); | ||
|
||
var syntaxNode = this.CreateForEachVariableStatement(); | ||
Assert.True(ForEachVariableStatementSyntaxWrapper.IsInstance(syntaxNode)); | ||
} | ||
|
||
[Fact] | ||
public void TestConversionsNull() | ||
{ | ||
var syntaxNode = default(SyntaxNode); | ||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
|
||
StatementSyntax syntax = wrapper; | ||
Assert.Null(syntax); | ||
} | ||
|
||
[Fact] | ||
public void TestConversions() | ||
{ | ||
var syntaxNode = this.CreateForEachVariableStatement(); | ||
var wrapper = (ForEachVariableStatementSyntaxWrapper)syntaxNode; | ||
|
||
StatementSyntax syntax = wrapper; | ||
Assert.Same(syntaxNode, syntax); | ||
} | ||
|
||
[Fact] | ||
public void TestInvalidConversion() | ||
{ | ||
var syntaxNode = SyntaxFactory.LiteralExpression(SyntaxKind.NullLiteralExpression); | ||
Assert.Throws<InvalidCastException>(() => (ForEachVariableStatementSyntaxWrapper)syntaxNode); | ||
} | ||
|
||
private ForEachVariableStatementSyntax CreateForEachVariableStatement() | ||
{ | ||
return SyntaxFactory.ForEachVariableStatement( | ||
SyntaxFactory.Token(SyntaxKind.ForEachKeyword), | ||
SyntaxFactory.Token(SyntaxKind.OpenParenToken), | ||
SyntaxFactory.LiteralExpression(SyntaxKind.NullLiteralExpression), | ||
SyntaxFactory.Token(SyntaxKind.InKeyword), | ||
SyntaxFactory.LiteralExpression(SyntaxKind.NullLiteralExpression), | ||
SyntaxFactory.Token(SyntaxKind.CloseParenToken), | ||
SyntaxFactory.EmptyStatement()); | ||
} | ||
} | ||
} |
Oops, something went wrong.