RFR: JDK-8317635: Improve GetClassFields test to verify correctness of field order [v2]
Serguei Spitsyn
sspitsyn at openjdk.org
Thu Oct 19 00:26:51 UTC 2023
On Wed, 18 Oct 2023 01:40:18 GMT, Alex Menkov <amenkov at openjdk.org> wrote:
>> All test cases in getclfld007 had 1 (or 0) field in test classes/interfaces.
>> The change adds several fields in one of the test classes to verify order of the returned fields (as described by GetClassFields spec: "in the order they occur in the class file").
>> Field order in the class file is not guaranteed to be the same as in the source, so information about expected fields and expected order is extracted by ASM (it parses class file sequentially).
>> This allows to drop hardcoded field name/type in native part.
>>
>> Additionally did some test cleanup:
>> - dropped "printdump" stuff (the test always logs reported fields);
>> - removed unused `generic` in native check() method, added deallocation of `name` and `sig`
>
> Alex Menkov has updated the pull request incrementally with one additional commit since the last revision:
>
> get field order from class file
test/hotspot/jtreg/vmTestbase/nsk/jvmti/GetClassFields/getclfld007.java line 87:
> 85:
> 86: // helper class to get list of the class field
> 87: // in the order they appear in the class file
Nit: `class field` => `class fields`.
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/16131#discussion_r1364729022
More information about the serviceability-dev
mailing list