From f3cd52e3c73ad525456a20b5190a3a97e862ec15 Mon Sep 17 00:00:00 2001 From: Erik Gahlin Date: Tue, 18 Feb 2020 22:25:08 +0100 Subject: [PATCH] 8210977: jdk/jfr/event/oldobject/TestThreadLocalLeak.java fails to find ThreadLocalObject Reviewed-by: mgronlun, mseledtsov --- .../event/oldobject/TestThreadLocalLeak.java | 22 +++++++++++-------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/test/jdk/jdk/jfr/event/oldobject/TestThreadLocalLeak.java b/test/jdk/jdk/jfr/event/oldobject/TestThreadLocalLeak.java index 2143b617f63..8bb7054909e 100644 --- a/test/jdk/jdk/jfr/event/oldobject/TestThreadLocalLeak.java +++ b/test/jdk/jdk/jfr/event/oldobject/TestThreadLocalLeak.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -57,14 +57,18 @@ public class TestThreadLocalLeak { public static void main(String[] args) throws Exception { WhiteBox.setWriteAllObjectSamples(true); - try (Recording r = new Recording()) { - r.enable(EventNames.OldObjectSample).withStackTrace().with("cutoff", "infinity"); - r.start(); - allocateThreadLocal(); - r.stop(); - List events = Events.fromRecording(r); - if (OldObjects.countMatchingEvents(events, ThreadLocalObject[].class, null, null, -1, "allocateThreadLocal") == 0) { - throw new Exception("Could not find thread local object " + ThreadLocalObject.class); + while (true) { + try (Recording r = new Recording()) { + r.enable(EventNames.OldObjectSample).withStackTrace().with("cutoff", "infinity"); + r.start(); + allocateThreadLocal(); + r.stop(); + List events = Events.fromRecording(r); + if (OldObjects.countMatchingEvents(events, ThreadLocalObject[].class, null, null, -1, "allocateThreadLocal") > 0) { + return; + } + System.out.println("Failed to find ThreadLocalObject leak. Retrying."); + threadLocal.get().clear(); } } }