[ 
https://issues.apache.org/jira/browse/GROOVY-8938?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Anton Pryamostanov updated GROOVY-8938:
---------------------------------------
    Description: 
Note: **this seems to be a quite major issue**, kindly look at this one with 
emphasis.

Please see the below test case:
SubClass extends the SuperClass and overrides the field "inheritedField".
{code}
class OtherClass {
    String otherField
    OtherClass(String otherField) {
        this.otherField = otherField
    }
    String toString() {
        return otherField
    }
}
class SuperClass {
    final OtherClass inheritedField = new OtherClass("Super Class String")
}
class SubClass extends SuperClass {
    final OtherClass inheritedField = new OtherClass("Sub Class String")
}
SuperClass superClass = new SuperClass()
SubClass subClass = new SubClass()
assert subClass.inheritedField.toString() == "Sub Class String"
{code}

*Actual result*: assertion fails
*Expected result*: assertion should pass
*Note*: If "final" modifier is removed, assertion passes as expected.
This seems an issue with final field caching.

Assertion error text:
{code}
Assertion failed: 
assert subClass.inheritedField.toString() == "Sub Class String"
       |        |              |          |
       |        |              |          false
       |        |              'Super Class String'
       |        Super Class String
       SubClass@5b4b841f
        at ConsoleScript11.run(ConsoleScript11:18)
{code}

  was:
Note: **this seems to be a quite major issue**, kindly look at this one with 
emphasis.

Please see the below test case:
SubClass extends the SuperClass and overrides the field "inheritedField".
{code}
class OtherClass {
    String otherField
    OtherClass(String otherField) {
        this.otherField = otherField
    }
    String toString() {
        return otherField
    }
}
class SuperClass {
    final OtherClass inheritedField = new OtherClass("Super Class String")
}
class SubClass extends SuperClass {
    final OtherClass inheritedField = new OtherClass("Sub Class String")
}
SuperClass superClass = new SuperClass()
SubClass subClass = new SubClass()
assert subClass.inheritedField.toString() == "Sub Class String"
{code}

Actual result: assertion fails
Expected result: assertion should pass
Note: If "final" modifier is removed, assertion passes as expected.
This seems an issue with final field caching.


> Final field caching issues in inherited field.
> ----------------------------------------------
>
>                 Key: GROOVY-8938
>                 URL: https://issues.apache.org/jira/browse/GROOVY-8938
>             Project: Groovy
>          Issue Type: Bug
>          Components: groovy-runtime
>    Affects Versions: 2.5.4
>            Reporter: Anton Pryamostanov
>            Priority: Critical
>
> Note: **this seems to be a quite major issue**, kindly look at this one with 
> emphasis.
> Please see the below test case:
> SubClass extends the SuperClass and overrides the field "inheritedField".
> {code}
> class OtherClass {
>     String otherField
>     OtherClass(String otherField) {
>         this.otherField = otherField
>     }
>     String toString() {
>         return otherField
>     }
> }
> class SuperClass {
>     final OtherClass inheritedField = new OtherClass("Super Class String")
> }
> class SubClass extends SuperClass {
>     final OtherClass inheritedField = new OtherClass("Sub Class String")
> }
> SuperClass superClass = new SuperClass()
> SubClass subClass = new SubClass()
> assert subClass.inheritedField.toString() == "Sub Class String"
> {code}
> *Actual result*: assertion fails
> *Expected result*: assertion should pass
> *Note*: If "final" modifier is removed, assertion passes as expected.
> This seems an issue with final field caching.
> Assertion error text:
> {code}
> Assertion failed: 
> assert subClass.inheritedField.toString() == "Sub Class String"
>        |        |              |          |
>        |        |              |          false
>        |        |              'Super Class String'
>        |        Super Class String
>        SubClass@5b4b841f
>       at ConsoleScript11.run(ConsoleScript11:18)
> {code}



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to