From 30b4ff49ed7239d5dcd8808d1d49200e6079c35b Mon Sep 17 00:00:00 2001 From: summerji Date: Sun, 4 Oct 2020 00:29:26 -0700 Subject: [PATCH] fix: add final keyword checking in post increment operation expr --- .../engine/ast/UnaryOperationExpr.java | 12 +++++++++ .../engine/ast/UnaryOperationExprTest.java | 25 +++++++++++++------ 2 files changed, 29 insertions(+), 8 deletions(-) diff --git a/src/main/java/com/google/api/generator/engine/ast/UnaryOperationExpr.java b/src/main/java/com/google/api/generator/engine/ast/UnaryOperationExpr.java index f7d65af381..7c38beff02 100644 --- a/src/main/java/com/google/api/generator/engine/ast/UnaryOperationExpr.java +++ b/src/main/java/com/google/api/generator/engine/ast/UnaryOperationExpr.java @@ -72,6 +72,18 @@ private UnaryOperationExpr build() { UnaryOperationExpr unaryOperationExpr = autoBuild(); TypeNode exprType = unaryOperationExpr.expr().type(); OperatorKind operator = unaryOperationExpr.operatorKind(); + + // TODO: (summerji) Add Decl Check for variable. + // Add final keyword checking for post/prefix ++, -- when needed. + if (operator.equals(OperatorKind.UNARY_POST_INCREMENT) + && unaryOperationExpr.expr() instanceof VariableExpr) { + Preconditions.checkState( + !((VariableExpr) unaryOperationExpr.expr()).isFinal(), + String.format( + "Cannot assign a value to final variable '%s'.", + ((VariableExpr) unaryOperationExpr.expr()).variable().name())); + } + final String errorMsg = String.format( "Unary operator %s can not be applied to %s. ", operator, exprType.toString()); diff --git a/src/test/java/com/google/api/generator/engine/ast/UnaryOperationExprTest.java b/src/test/java/com/google/api/generator/engine/ast/UnaryOperationExprTest.java index c2321d1577..734156cf9c 100644 --- a/src/test/java/com/google/api/generator/engine/ast/UnaryOperationExprTest.java +++ b/src/test/java/com/google/api/generator/engine/ast/UnaryOperationExprTest.java @@ -21,7 +21,7 @@ public class UnaryOperationExprTest { /** =============================== Logic Not Operation Expr =============================== */ @Test - public void logicalNotOperationExpr_validBasic() { + public void validLogicalNotOperationExpr_basic() { VariableExpr variableExpr = VariableExpr.withVariable( Variable.builder().setName("x").setType(TypeNode.BOOLEAN).build()); @@ -30,7 +30,7 @@ public void logicalNotOperationExpr_validBasic() { } @Test - public void logicalNot_validBoxedType() { + public void validLogicalNot_boxedType() { VariableExpr variableExpr = VariableExpr.withVariable( Variable.builder().setName("x").setType(TypeNode.BOOLEAN_OBJECT).build()); @@ -39,7 +39,7 @@ public void logicalNot_validBoxedType() { } @Test - public void logicalNot_invalidNumericType() { + public void invalidLogicalNot_numericType() { VariableExpr variableExpr = VariableExpr.withVariable(Variable.builder().setName("x").setType(TypeNode.INT).build()); assertThrows( @@ -47,7 +47,7 @@ public void logicalNot_invalidNumericType() { } @Test - public void logicalNot_invalidReferenceType() { + public void invalidLogicalNot_referenceType() { VariableExpr variableExpr = VariableExpr.withVariable(Variable.builder().setName("x").setType(TypeNode.STRING).build()); assertThrows( @@ -58,7 +58,7 @@ public void logicalNot_invalidReferenceType() { * =============================== Post Increment Operation Expr =============================== */ @Test - public void postIncrement_validBasic() { + public void validPostIncrement_basic() { VariableExpr variableExpr = VariableExpr.withVariable(Variable.builder().setName("x").setType(TypeNode.INT).build()); UnaryOperationExpr.postfixIncrementWithExpr(variableExpr); @@ -66,7 +66,7 @@ public void postIncrement_validBasic() { } @Test - public void postIncrement_validBoxedType() { + public void validPostIncrement_boxedType() { VariableExpr variableExpr = VariableExpr.withVariable( Variable.builder().setName("x").setType(TypeNode.FLOAT_OBJECT).build()); @@ -75,7 +75,7 @@ public void postIncrement_validBoxedType() { } @Test - public void postIncrement_invalidBoxedBooleanType() { + public void invalidPostIncrement_boxedBooleanType() { VariableExpr variableExpr = VariableExpr.withVariable( Variable.builder().setName("x").setType(TypeNode.BOOLEAN_OBJECT).build()); @@ -85,11 +85,20 @@ public void postIncrement_invalidBoxedBooleanType() { } @Test - public void postIncrement_invalidReferenceType() { + public void invalidPostIncrement_referenceType() { VariableExpr variableExpr = VariableExpr.withVariable(Variable.builder().setName("x").setType(TypeNode.STRING).build()); assertThrows( IllegalStateException.class, () -> UnaryOperationExpr.postfixIncrementWithExpr(variableExpr)); } + + @Test + public void invalidPostIncrement_finalVariable() { + Variable var = Variable.builder().setName("i").setType(TypeNode.INT).build(); + VariableExpr variableExpr = VariableExpr.builder().setIsFinal(true).setVariable(var).build(); + assertThrows( + IllegalStateException.class, + () -> UnaryOperationExpr.postfixIncrementWithExpr(variableExpr)); + } }