8202392: [TESTBUG] open source vm testbase heapdump tests
Reviewed-by: sspitsyn, mseledtsov
This commit is contained in:
parent
ce4698fadb
commit
f575533a17
@ -123,4 +123,7 @@ vmTestbase/nsk/jdi/VirtualMachine/redefineClasses/redefineclasses023/TestDescrip
|
||||
vmTestbase/nsk/jdi/EventQueue/remove_l/remove_l005/TestDescription.java 8068225 generic-all
|
||||
vmTestbase/nsk/jdi/stress/ClassPrepareEvents/ClassPrepareEvents001/ClassPrepareEvents001.java 6426321 generic-all
|
||||
|
||||
vmTestbase/heapdump/JMapHeapCore/TestDescription.java 8023376,8001227,8051445 generic-all
|
||||
vmTestbase/heapdump/JMapMetaspaceCore/TestDescription.java 8023376,8001227,8051445 generic-all
|
||||
|
||||
#############################################################################
|
||||
|
@ -1150,3 +1150,14 @@ vmTestbase_nsk_jdi_quick = \
|
||||
vmTestbase/nsk/jdi/StackFrame/getArgumentValues/getArgumentValues002/getArgumentValues002.java \
|
||||
vmTestbase/nsk/jdi/StackFrame/getArgumentValues/getArgumentValues003/getArgumentValues003.java
|
||||
|
||||
# Heap dump tests
|
||||
vmTestbase_vm_heapdump = \
|
||||
vmTestbase/heapdump/
|
||||
|
||||
vmTestbase_vm_heapdump_quick = \
|
||||
vmTestbase/heapdump/OnOOMToFile/TestDescription.java \
|
||||
vmTestbase/heapdump/OnOOMToFileMetaspace/TestDescription.java \
|
||||
vmTestbase/heapdump/OnOOMToPath/TestDescription.java \
|
||||
vmTestbase/heapdump/JMapHeapCore/TestDescription.java \
|
||||
vmTestbase/heapdump/JMapMetaspace/TestDescription.java
|
||||
|
||||
|
@ -0,0 +1,23 @@
|
||||
#
|
||||
# Copyright (c) 2017, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
exclusiveAccess.dirs=.
|
@ -0,0 +1,43 @@
|
||||
/*
|
||||
* Copyright (c) 2017, 2018, 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
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
/*
|
||||
* @test
|
||||
*
|
||||
* @summary converted from VM testbase heapdump/JMapHeap.
|
||||
* VM testbase keywords: [heapdump, feature_heapdump, nonconcurrent, jdk]
|
||||
* VM testbase readme:
|
||||
* DESCRIPTION
|
||||
* This test verifies that heap dump created by JMap is able to be
|
||||
* parsed by HprofParser. It fills the heap with objects of different types
|
||||
* till OutOfMemoryError, then uses JMap to create heap dump and then
|
||||
* verifies created heap dump with HprofParser.
|
||||
*
|
||||
* @library /vmTestbase
|
||||
* /test/lib
|
||||
* @run driver jdk.test.lib.FileInstaller . .
|
||||
* @build jdk.test.lib.hprof.HprofParser
|
||||
* heapdump.share.EatMemory
|
||||
* @run shell/timeout=300 run.sh
|
||||
*/
|
||||
|
51
test/hotspot/jtreg/vmTestbase/heapdump/JMapHeap/run.sh
Normal file
51
test/hotspot/jtreg/vmTestbase/heapdump/JMapHeap/run.sh
Normal file
@ -0,0 +1,51 @@
|
||||
#!/bin/sh
|
||||
# Copyright (c) 2007, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
|
||||
. $TESTSRC/../share/common.sh
|
||||
|
||||
JAVA_OPTS="${JAVA_OPTS} -XX:-UseGCOverheadLimit -Xmx1G"
|
||||
|
||||
DUMPFILE=heap.bin
|
||||
|
||||
rm -f ${DUMPFILE}
|
||||
|
||||
JMAP_DUMP_OPT="-dump:format=b,file=${DUMPFILE}"
|
||||
|
||||
${JAVA} ${JAVA_OPTS} heapdump.share.EatMemory -exec "${JMAP} ${JMAP_DUMP_OPT} %p"
|
||||
|
||||
status=$?
|
||||
|
||||
if [ $status -ne 0 ]; then
|
||||
fail "Java exited with exit status: $status"
|
||||
fi
|
||||
|
||||
if [ ! -f "${DUMPFILE}" ]; then
|
||||
fail "Dump file was not created: $DUMPFILE"
|
||||
fi
|
||||
|
||||
verify_heapdump ${DUMPFILE}
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
fail "Verification of heap dump failed"
|
||||
fi
|
||||
|
||||
pass
|
@ -0,0 +1,45 @@
|
||||
/*
|
||||
* Copyright (c) 2017, 2018, 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
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
|
||||
/*
|
||||
* @test
|
||||
*
|
||||
* @summary converted from VM testbase heapdump/JMapHeapCore.
|
||||
* VM testbase keywords: [heapdump, feature_heapdump, nonconcurrent.jdk, quick, quarantine]
|
||||
* VM testbase comments: JDK-8023376 JDK-8001227 JDK-8051445
|
||||
* VM testbase readme:
|
||||
* DESCRIPTION
|
||||
* This test verifies that heap dump created by jhsdb is able to be
|
||||
* parsed by HprofParser. It fills the heap with objects of different types
|
||||
* till OutOfMemoryError, forces core dump, then uses jhsdb on core file
|
||||
* to create heap dump and then verifies created heap dump with HprofParser.
|
||||
*
|
||||
* @library /vmTestbase
|
||||
* /test/lib
|
||||
* @run driver jdk.test.lib.FileInstaller . .
|
||||
* @build jdk.test.lib.hprof.HprofParser
|
||||
* heapdump.share.EatMemory
|
||||
* @run shell/timeout=300 run.sh
|
||||
*/
|
||||
|
88
test/hotspot/jtreg/vmTestbase/heapdump/JMapHeapCore/run.sh
Normal file
88
test/hotspot/jtreg/vmTestbase/heapdump/JMapHeapCore/run.sh
Normal file
@ -0,0 +1,88 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# Copyright (c) 2007, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
|
||||
. $TESTSRC/../share/common.sh
|
||||
|
||||
JAVA_OPTS="${JAVA_OPTS} -XX:-UseGCOverheadLimit -XX:-TransmitErrorReport"
|
||||
|
||||
if [ $CORE_SUPPORTED -eq 0 ]; then
|
||||
pass "Core dump is not supported"
|
||||
fi
|
||||
|
||||
DUMPFILE=heap.bin
|
||||
|
||||
rm -f ${DUMPFILE}
|
||||
|
||||
ulimit -c unlimited || true
|
||||
|
||||
echo "Below 'Unexpected error' is actually expected - JVM is forced to dump core"
|
||||
${JAVA} ${JAVA_OPTS} heapdump.share.EatMemory -core &
|
||||
|
||||
pid=$!
|
||||
|
||||
wait $pid
|
||||
|
||||
status=$?
|
||||
|
||||
if [ $status -eq 0 ]; then
|
||||
pass "Java exited with exit status: $status"
|
||||
fi
|
||||
|
||||
for CORE in core* /cores/core.$pid; do
|
||||
[ -e "$CORE" ] && break;
|
||||
done
|
||||
|
||||
if [ ! -f "$CORE" ]; then
|
||||
fail "Java exited with exit status: $status, but core file was not created"
|
||||
fi
|
||||
echo "Found core file: $CORE"
|
||||
|
||||
JMAP_DUMP_OPT="--binaryheap --dumpfile=${DUMPFILE}"
|
||||
EXE_OPT="--exe"
|
||||
CORE_OPT="--core"
|
||||
JHSDB_OPT="jmap"
|
||||
|
||||
${JHSDB} ${JHSDB_OPT} ${JMAP_DUMP_OPT} ${EXE_OPT} ${JAVA} ${CORE_OPT} ${CORE}
|
||||
|
||||
status=$?
|
||||
if [ $status -ne 0 ]; then
|
||||
fail "jmap exited with exit status $status"
|
||||
fi
|
||||
|
||||
if [ ! -f "${DUMPFILE}" ]; then
|
||||
fail "Dump file was not created: $DUMPFILE"
|
||||
fi
|
||||
|
||||
verify_heapdump ${DUMPFILE}
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
fail "Verification of heap dump failed"
|
||||
fi
|
||||
|
||||
if [ "$TEST_CLEANUP" != "false" ]; then
|
||||
rm -f ${CORE}
|
||||
rm -f hs_err_pid*
|
||||
fi
|
||||
|
||||
pass
|
@ -0,0 +1,23 @@
|
||||
#
|
||||
# Copyright (c) 2017, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
exclusiveAccess.dirs=.
|
@ -0,0 +1,43 @@
|
||||
/*
|
||||
* Copyright (c) 2017, 2018, 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
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
|
||||
/*
|
||||
* @test
|
||||
*
|
||||
* @summary converted from VM testbase heapdump/JMapMetaspace.
|
||||
* VM testbase keywords: [heapdump, feature_heapdump, nonconcurrent, jdk, quick]
|
||||
* VM testbase readme:
|
||||
* DESCRIPTION
|
||||
* This test verifies that heap dump created by JMap is able to be
|
||||
* parsed by HprofParser. It fills metaspace with classes till OutOfMemoryError,
|
||||
* then uses JMap to create heap dump and then verifies created heap dump with HprofParser.
|
||||
*
|
||||
* @library /vmTestbase
|
||||
* /test/lib
|
||||
* @run driver jdk.test.lib.FileInstaller . .
|
||||
* @build jdk.test.lib.hprof.HprofParser
|
||||
* heapdump.share.EatMemory
|
||||
* @run shell/timeout=300 run.sh
|
||||
*/
|
||||
|
53
test/hotspot/jtreg/vmTestbase/heapdump/JMapMetaspace/run.sh
Normal file
53
test/hotspot/jtreg/vmTestbase/heapdump/JMapMetaspace/run.sh
Normal file
@ -0,0 +1,53 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# Copyright (c) 2014, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
|
||||
. $TESTSRC/../share/common.sh
|
||||
|
||||
JAVA_OPTS="${JAVA_OPTS} -XX:-UseGCOverheadLimit -XX:MaxMetaspaceSize=64m"
|
||||
|
||||
DUMPFILE=heap.bin
|
||||
|
||||
rm -f ${DUMPFILE}
|
||||
|
||||
JMAP_DUMP_OPT="-dump:format=b,file=${DUMPFILE}"
|
||||
|
||||
${JAVA} ${JAVA_OPTS} heapdump.share.EatMemory -metaspace -exec "${JMAP} ${JMAP_DUMP_OPT} %p"
|
||||
|
||||
status=$?
|
||||
|
||||
if [ $status -ne 0 ]; then
|
||||
fail "Java exited with exit status: $status"
|
||||
fi
|
||||
|
||||
if [ ! -f "${DUMPFILE}" ]; then
|
||||
fail "Dump file was not created: ${DUMPFILE}"
|
||||
fi
|
||||
|
||||
verify_heapdump ${DUMPFILE}
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
fail "Verification of heap dump failed"
|
||||
fi
|
||||
|
||||
pass
|
@ -0,0 +1,23 @@
|
||||
#
|
||||
# Copyright (c) 2017, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
exclusiveAccess.dirs=.
|
@ -0,0 +1,45 @@
|
||||
/*
|
||||
* Copyright (c) 2017, 2018, 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
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
|
||||
/*
|
||||
* @test
|
||||
*
|
||||
* @summary converted from VM testbase heapdump/JMapMetaspaceCore.
|
||||
* VM testbase keywords: [heapdump, feature_heapdump, nonconcurrent, jdk, quarantine]
|
||||
* VM testbase comments: JDK-8023376 JDK-8001227 JDK-8051445
|
||||
* VM testbase readme:
|
||||
* DESCRIPTION
|
||||
* This test verifies that heap dump created by jhsdb is able to be
|
||||
* parsed by HprofParser. It fills metaspace with classes till OutOfMemoryError,
|
||||
* forces core dump, then uses jhsdb one core file to create heap dump
|
||||
* and then verifies created heap dump with HprofParser.
|
||||
*
|
||||
* @library /vmTestbase
|
||||
* /test/lib
|
||||
* @run driver jdk.test.lib.FileInstaller . .
|
||||
* @build jdk.test.lib.hprof.HprofParser
|
||||
* heapdump.share.EatMemory
|
||||
* @run shell/timeout=300 run.sh
|
||||
*/
|
||||
|
@ -0,0 +1,90 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# Copyright (c) 2014, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
|
||||
. $TESTSRC/../share/common.sh
|
||||
|
||||
JAVA_OPTS="${JAVA_OPTS} -XX:-UseGCOverheadLimit -XX:MaxMetaspaceSize=64m -XX:-TransmitErrorReport"
|
||||
|
||||
if [ $CORE_SUPPORTED -eq 0 ]; then
|
||||
pass "Core dump is not supported"
|
||||
fi
|
||||
|
||||
DUMPFILE=heap.bin
|
||||
|
||||
rm -f ${DUMPFILE}
|
||||
|
||||
ulimit -c unlimited || true
|
||||
|
||||
echo "Below 'Unexpected error' is actually expected - JVM is forced to dump core"
|
||||
|
||||
${JAVA} ${JAVA_OPTS} heapdump.share.EatMemory -metaspace -core &
|
||||
|
||||
pid=$!
|
||||
|
||||
wait $pid
|
||||
|
||||
status=$?
|
||||
|
||||
if [ $status -eq 0 ]; then
|
||||
pass "Java exited with exit status: $status"
|
||||
fi
|
||||
|
||||
for CORE in core* /cores/core.$pid; do
|
||||
[ -e "$CORE" ] && break;
|
||||
done
|
||||
|
||||
if [ ! -f "$CORE" ]; then
|
||||
fail "Java exited with exit status $status, but core file was not created"
|
||||
fi
|
||||
|
||||
echo "Found core file: $CORE"
|
||||
|
||||
JMAP_DUMP_OPT="--binaryheap --dumpfile=${DUMPFILE}"
|
||||
EXE_OPT="--exe"
|
||||
CORE_OPT="--core"
|
||||
JHSDB_OPT="jmap"
|
||||
|
||||
${JHSDB} ${JHSDB_OPT} ${JMAP_DUMP_OPT} ${EXE_OPT} ${JAVA} ${CORE_OPT} ${CORE}
|
||||
|
||||
status=$?
|
||||
if [ $status -ne 0 ]; then
|
||||
fail "jmap exited with exit status $status"
|
||||
fi
|
||||
|
||||
if [ ! -f "${DUMPFILE}" ]; then
|
||||
fail "Dump file was not created: $DUMPFILE"
|
||||
fi
|
||||
|
||||
verify_heapdump ${DUMPFILE}
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
fail "Verification of heap dump failed"
|
||||
fi
|
||||
|
||||
if [ "$TEST_CLEANUP" != "false" ]; then
|
||||
rm -f ${CORE}
|
||||
rm -f hs_err_pid*
|
||||
fi
|
||||
|
||||
pass
|
@ -0,0 +1,23 @@
|
||||
#
|
||||
# Copyright (c) 2017, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
exclusiveAccess.dirs=.
|
@ -0,0 +1,45 @@
|
||||
/*
|
||||
* Copyright (c) 2017, 2018, 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
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
|
||||
/*
|
||||
* @test
|
||||
*
|
||||
* @summary converted from VM testbase heapdump/OnOOMToFile.
|
||||
* VM testbase keywords: [heapdump, feature_heapdump, nonconcurrent, jdk, quick]
|
||||
* VM testbase readme:
|
||||
* DESCRIPTION
|
||||
* This test verifies -XX:+HeapDumpOnOutOfMemory VM option. It
|
||||
* fills the heap with objects of different types till OutOfMemoryError
|
||||
* and then verifies created heap dump with HprofParser.
|
||||
* COMMENTS
|
||||
* This test uses -XX:HeapDumpPath= option pointing to file.
|
||||
*
|
||||
* @library /vmTestbase
|
||||
* /test/lib
|
||||
* @run driver jdk.test.lib.FileInstaller . .
|
||||
* @build jdk.test.lib.hprof.HprofParser
|
||||
* heapdump.share.EatMemory
|
||||
* @run shell/timeout=300 run.sh
|
||||
*/
|
||||
|
53
test/hotspot/jtreg/vmTestbase/heapdump/OnOOMToFile/run.sh
Normal file
53
test/hotspot/jtreg/vmTestbase/heapdump/OnOOMToFile/run.sh
Normal file
@ -0,0 +1,53 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# Copyright (c) 2007, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
|
||||
. $TESTSRC/../share/common.sh
|
||||
|
||||
JAVA_OPTS="${JAVA_OPTS} -XX:-UseGCOverheadLimit"
|
||||
|
||||
DUMPFILE=${DUMPBASE}/java.hprof
|
||||
|
||||
rm -f ${DUMPFILE}
|
||||
|
||||
JAVA_OPTS="${JAVA_OPTS} -Xmx`get_max_heap_size $JAVA_OPTS`"
|
||||
|
||||
${JAVA} ${JAVA_OPTS} -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=${DUMPFILE} heapdump.share.EatMemory
|
||||
|
||||
status=$?
|
||||
|
||||
if [ $status -ne 0 ]; then
|
||||
fail "Java command exited with exit status $status"
|
||||
fi
|
||||
|
||||
if [ ! -f "${DUMPFILE}" ]; then
|
||||
fail "Dump file was not created: ${DUMPFILE}"
|
||||
fi
|
||||
|
||||
verify_heapdump ${DUMPFILE}
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
fail "Verification of heap dump failed"
|
||||
fi
|
||||
|
||||
pass
|
@ -0,0 +1,23 @@
|
||||
#
|
||||
# Copyright (c) 2017, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
exclusiveAccess.dirs=.
|
@ -0,0 +1,45 @@
|
||||
/*
|
||||
* Copyright (c) 2017, 2018, 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
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
|
||||
/*
|
||||
* @test
|
||||
*
|
||||
* @summary converted from VM testbase heapdump/OnOOMToFileMetaspace.
|
||||
* VM testbase keywords: [heapdump, feature_heapdump, nonconcurrent, jdk, quick]
|
||||
* VM testbase readme:
|
||||
* DESCRIPTION
|
||||
* This test verifies -XX:+HeapDumpOnOutOfMemory VM option. It fills
|
||||
* metaspace with classes till OutOfMemoryError is thrown and then
|
||||
* verifies create heap dump with HprofParser.
|
||||
* COMMENTS
|
||||
* This test uses -XX:HeapDumpPath= option pointing to file.
|
||||
*
|
||||
* @library /vmTestbase
|
||||
* /test/lib
|
||||
* @run driver jdk.test.lib.FileInstaller . .
|
||||
* @build jdk.test.lib.hprof.HprofParser
|
||||
* heapdump.share.EatMemory
|
||||
* @run shell/timeout=300 run.sh
|
||||
*/
|
||||
|
@ -0,0 +1,53 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# Copyright (c) 2014, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
|
||||
. $TESTSRC/../share/common.sh
|
||||
|
||||
JAVA_OPTS="${JAVA_OPTS} -XX:-UseGCOverheadLimit -XX:MaxMetaspaceSize=64m"
|
||||
|
||||
DUMPFILE=${DUMPBASE}/java.hprof
|
||||
|
||||
rm -f ${DUMPFILE}
|
||||
|
||||
JAVA_OPTS="${JAVA_OPTS} -Xmx`get_max_heap_size $JAVA_OPTS`"
|
||||
|
||||
${JAVA} ${JAVA_OPTS} -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=${DUMPFILE} heapdump.share.EatMemory -metaspace
|
||||
|
||||
status=$?
|
||||
|
||||
if [ $status -ne 0 ]; then
|
||||
fail "Java command exited with exit status $status"
|
||||
fi
|
||||
|
||||
if [ ! -f "${DUMPFILE}" ]; then
|
||||
fail "Dump file was not created: ${DUMPFILE}"
|
||||
fi
|
||||
|
||||
verify_heapdump ${DUMPFILE}
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
fail "Verification of heap dump failed"
|
||||
fi
|
||||
|
||||
pass
|
@ -0,0 +1,23 @@
|
||||
#
|
||||
# Copyright (c) 2017, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
exclusiveAccess.dirs=.
|
@ -0,0 +1,46 @@
|
||||
/*
|
||||
* Copyright (c) 2017, 2018, 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
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
|
||||
/*
|
||||
* @test
|
||||
*
|
||||
* @summary converted from VM testbase heapdump/OnOOMToPath.
|
||||
* VM testbase keywords: [heapdump, feature_heapdump, nonconcurrent, jdk, quick]
|
||||
* VM testbase readme:
|
||||
* DESCRIPTION
|
||||
* This test verifies -XX:+HeapDumpOnOutOfMemory VM option. It
|
||||
* fills the heap with objects of different types till OutOfMemoryError
|
||||
* and then verifies created heap dump with HprofParser.
|
||||
* COMMENTS
|
||||
* This test uses -XX:HeapDumpPath= option pointing to directory in which
|
||||
* heap dump file should be created.
|
||||
*
|
||||
* @library /vmTestbase
|
||||
* /test/lib
|
||||
* @run driver jdk.test.lib.FileInstaller . .
|
||||
* @build jdk.test.lib.hprof.HprofParser
|
||||
* heapdump.share.EatMemory
|
||||
* @run shell/timeout=300 run.sh
|
||||
*/
|
||||
|
57
test/hotspot/jtreg/vmTestbase/heapdump/OnOOMToPath/run.sh
Normal file
57
test/hotspot/jtreg/vmTestbase/heapdump/OnOOMToPath/run.sh
Normal file
@ -0,0 +1,57 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# Copyright (c) 2007, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
#
|
||||
|
||||
. $TESTSRC/../share/common.sh
|
||||
|
||||
JAVA_OPTS="${JAVA_OPTS} -XX:-UseGCOverheadLimit"
|
||||
|
||||
DUMPPATH=${DUMPBASE}/dumps
|
||||
|
||||
rm -rf ${DUMPPATH}
|
||||
|
||||
mkdir -p ${DUMPPATH}
|
||||
|
||||
JAVA_OPTS="${JAVA_OPTS} -Xmx`get_max_heap_size $JAVA_OPTS`"
|
||||
|
||||
${JAVA} ${JAVA_OPTS} -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=${DUMPPATH} heapdump.share.EatMemory
|
||||
|
||||
status=$?
|
||||
|
||||
if [ $status -ne 0 ]; then
|
||||
fail "Java command exited with exit status $status"
|
||||
fi
|
||||
|
||||
DUMPFILE=`ls ${DUMPPATH}/*`
|
||||
|
||||
if [ ! -f "${DUMPFILE}" ]; then
|
||||
fail "Dump file was not created: $DUMPPATH/\*"
|
||||
fi
|
||||
|
||||
verify_heapdump ${DUMPFILE}
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
fail "Verification of heap dump failed"
|
||||
fi
|
||||
|
||||
pass
|
38
test/hotspot/jtreg/vmTestbase/heapdump/README
Normal file
38
test/hotspot/jtreg/vmTestbase/heapdump/README
Normal file
@ -0,0 +1,38 @@
|
||||
Copyright (c) 2007, 2018, 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
|
||||
under the terms of the GNU General Public License version 2 only, as
|
||||
published by the Free Software Foundation.
|
||||
|
||||
This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
version 2 for more details (a copy is included in the LICENSE file that
|
||||
accompanied this code).
|
||||
|
||||
You should have received a copy of the GNU General Public License version
|
||||
2 along with this work; if not, write to the Free Software Foundation,
|
||||
Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
|
||||
Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
or visit www.oracle.com if you need additional information or have any
|
||||
questions.
|
||||
|
||||
heapdump/JMapHeap
|
||||
test for heapdump for jmap on live process
|
||||
heapdump/JMapHeapCore
|
||||
test for heap for jmap on core file
|
||||
heapdump/JMapMetaspace
|
||||
test for heapdump for jmap on live process, fills metaspace with classes
|
||||
heapdump/JMapMetaspaceCore
|
||||
test for heap for jmap on core file, fills metaspace with classes
|
||||
heapdump/OnOOMToFile
|
||||
test for -XX:+HeapDumpOnOutOfMemoryError and -XX:HeapDumpPath option
|
||||
for file. This test fills heap with objects of different types.
|
||||
heapdump/OnOOMToFileMetaspace
|
||||
the same test as OnOOMToFile, but it fills metaspace with classes
|
||||
heapdump/OnOOMToPath
|
||||
the same test as OnOOMToFile for -XX:HeapDumpPath option that points to directory
|
||||
heapdump/OnOOMRun
|
||||
test for -XX:OnOutOfMemoryError option
|
262
test/hotspot/jtreg/vmTestbase/heapdump/share/EatMemory.java
Normal file
262
test/hotspot/jtreg/vmTestbase/heapdump/share/EatMemory.java
Normal file
@ -0,0 +1,262 @@
|
||||
/*
|
||||
* Copyright (c) 2007, 2018, 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
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
package heapdump.share;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.ArrayList;
|
||||
import java.io.InputStreamReader;
|
||||
import java.io.BufferedReader;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.io.OutputStream;
|
||||
import java.util.Random;
|
||||
|
||||
import vm.share.ProcessUtils;
|
||||
|
||||
import java.util.LinkedList;
|
||||
|
||||
import nsk.share.gc.gp.classload.GeneratedClassProducer;
|
||||
|
||||
/**
|
||||
* This test eats memory by generating random garbage.
|
||||
* <p>
|
||||
* This program can eat either heap or metaspace using
|
||||
* interned strings depending on parameter metaspace. After this, it
|
||||
* can also force JVM to show dump, dump core or execute some command.
|
||||
* The following command line switches are supported:
|
||||
* <p>
|
||||
* "-sleepTime" time to sleep
|
||||
* "-signal" show dump after OOM
|
||||
* "-metaspace" eat metaspace
|
||||
* "-core" dump core after OOM
|
||||
* "-exec command" execute command after OOM
|
||||
*/
|
||||
public class EatMemory {
|
||||
private long sleepTime;
|
||||
private boolean signal;
|
||||
private boolean metaspace;
|
||||
private boolean core;
|
||||
private String exec;
|
||||
private final BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
|
||||
private long initialFactor = 50;
|
||||
private long minChunk = 1000;
|
||||
private long factor = 5;
|
||||
private long chunk;
|
||||
private Runtime runtime = Runtime.getRuntime();
|
||||
private int n = 0;
|
||||
private final int arrayExtraSize = 12;
|
||||
private final int stringLength = 128;
|
||||
private byte[] reserved = new byte[(int) (runtime.maxMemory() / 20)];
|
||||
private List storage = new ArrayList();
|
||||
private List strings = new ArrayList();
|
||||
|
||||
/**
|
||||
* @param sleepTime time to sleep
|
||||
* @param signal true if need to force JVM to show dump (Ctrl-Break / Ctrl-/) after OOM
|
||||
* @param metaspace true if need to eat metaspace
|
||||
* @param core true if need to force JVM to dump core
|
||||
* @param exec command to execute after OOM
|
||||
*/
|
||||
public EatMemory(long sleepTime, boolean signal, boolean metaspace, boolean core, String exec) {
|
||||
this.sleepTime = sleepTime;
|
||||
this.signal = signal;
|
||||
this.metaspace = metaspace;
|
||||
this.core = core;
|
||||
this.exec = exec;
|
||||
}
|
||||
|
||||
private int getSize(long chunk, long factor) {
|
||||
return (int) Math.min(Integer.MAX_VALUE, (chunk - arrayExtraSize) / factor);
|
||||
}
|
||||
|
||||
private Object create(long chunk) {
|
||||
switch (++n % 8) {
|
||||
case 0:
|
||||
return new byte[getSize(chunk, 1)];
|
||||
case 1:
|
||||
return new short[getSize(chunk, 2)];
|
||||
case 2:
|
||||
return new char[getSize(chunk, 2)];
|
||||
case 3:
|
||||
return new boolean[getSize(chunk, 1)];
|
||||
case 4:
|
||||
return new long[getSize(chunk, 8)];
|
||||
case 5:
|
||||
return new float[getSize(chunk, 4)];
|
||||
case 6:
|
||||
return new double[getSize(chunk, 8)];
|
||||
case 7:
|
||||
return new Object[getSize(chunk, 16)];
|
||||
default:
|
||||
// Should never happen
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public void eatHeap() {
|
||||
try {
|
||||
int[][] arrays = new int[Integer.MAX_VALUE / 2][];
|
||||
for (int i = 0; ; ++i) {
|
||||
arrays[i] = new int[Integer.MAX_VALUE / 2];
|
||||
}
|
||||
} catch (OutOfMemoryError x) {
|
||||
reserved = null;
|
||||
}
|
||||
}
|
||||
|
||||
public void eatMetaspace() {
|
||||
try {
|
||||
System.out.println("Starting eating metaspace...");
|
||||
GeneratedClassProducer gp = new GeneratedClassProducer();
|
||||
List<Class> lst = new LinkedList<Class>();
|
||||
System.out.println("... Oh, so tasty!");
|
||||
while (true) {
|
||||
lst.add(gp.create(0));
|
||||
}
|
||||
} catch (OutOfMemoryError e) {
|
||||
}
|
||||
}
|
||||
|
||||
public void eatMemory() throws IOException {
|
||||
if (metaspace)
|
||||
eatMetaspace();
|
||||
else
|
||||
eatHeap();
|
||||
reserved = null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sleep some time to give system time to process a signal, start
|
||||
* process, etc.
|
||||
*/
|
||||
private void sleepSome() {
|
||||
try {
|
||||
Thread.sleep(sleepTime);
|
||||
} catch (InterruptedException e) {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Throws an exception if execution was not successful.
|
||||
*/
|
||||
private void execute() throws IOException, InterruptedException {
|
||||
int pid = ProcessUtils.getPid();
|
||||
if (pid < 0) {
|
||||
throw new RuntimeException("Negative pid " + pid + "; Failed to executed " + exec);
|
||||
}
|
||||
exec = exec.replaceAll("%p", Integer.toString(pid));
|
||||
System.out.println("Executing " + exec);
|
||||
Process process = Runtime.getRuntime().exec(exec);
|
||||
sleepSome();
|
||||
process.waitFor();
|
||||
StringBuilder sb = copy(process.getInputStream(), System.out);
|
||||
sb.append(copy(process.getErrorStream(), System.out));
|
||||
if (process.exitValue() != 0) {
|
||||
// trying provide as much informative failure string
|
||||
// hoping, it will be the last line in the error stream...
|
||||
|
||||
|
||||
String failureCause = "Unknown";
|
||||
String allTheOutput = sb.toString();
|
||||
String[] lines = allTheOutput.split(System.getProperty("line.separator"));
|
||||
|
||||
for (int i = lines.length - 1; i >= 0; i--) {
|
||||
// Check that string is not empty
|
||||
if (!lines[i].trim().equals("")) {
|
||||
failureCause = lines[i];
|
||||
break;
|
||||
}
|
||||
}
|
||||
throw new RuntimeException(failureCause);
|
||||
}
|
||||
}
|
||||
|
||||
private StringBuilder copy(InputStream in, OutputStream out) throws IOException {
|
||||
byte[] buff = new byte[1000];
|
||||
StringBuilder sb = new StringBuilder();
|
||||
while (in.available() != 0) {
|
||||
n = in.read(buff, 0, buff.length);
|
||||
out.write(buff, 0, n);
|
||||
sb.append(new String(buff, 0, n));
|
||||
}
|
||||
return sb;
|
||||
}
|
||||
|
||||
public void run() throws Exception {
|
||||
eatMemory();
|
||||
if (signal) {
|
||||
ProcessUtils.sendCtrlBreak();
|
||||
sleepSome();
|
||||
|
||||
}
|
||||
if (exec != null) {
|
||||
execute();
|
||||
}
|
||||
if (core) {
|
||||
/*
|
||||
* We try to dump core here.
|
||||
* On Unix systems a signal is sent to the process. We need to wait some time
|
||||
* to give time to process it. On Windows systems, core dump is not supported
|
||||
* and we just do not do anything in this case.
|
||||
*/
|
||||
boolean res = ProcessUtils.dumpCore();
|
||||
if (res) {
|
||||
sleepSome();
|
||||
throw new RuntimeException("Signal sent, but core was not dumped");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws Exception {
|
||||
long sleepTime = 5000;
|
||||
boolean signal = false;
|
||||
boolean metaspace = false;
|
||||
boolean core = false;
|
||||
String exec = null;
|
||||
for (int i = 0; i < args.length; ++i) {
|
||||
if (args[i].equalsIgnoreCase("-sleepTime")) {
|
||||
if (++i < args.length) {
|
||||
long time = Long.parseLong(args[i]);
|
||||
if (time != 0)
|
||||
sleepTime = time;
|
||||
} else
|
||||
throw new RuntimeException("Argument expected after -sleepTime");
|
||||
}
|
||||
if (args[i].equalsIgnoreCase("-signal"))
|
||||
signal = true;
|
||||
if (args[i].equalsIgnoreCase("-metaspace"))
|
||||
metaspace = true;
|
||||
if (args[i].equalsIgnoreCase("-core"))
|
||||
core = true;
|
||||
if (args[i].equalsIgnoreCase("-exec")) {
|
||||
if (++i < args.length)
|
||||
exec = args[i];
|
||||
else
|
||||
throw new RuntimeException("Argument expected after -exec");
|
||||
}
|
||||
}
|
||||
new EatMemory(sleepTime, signal, metaspace, core, exec).run();
|
||||
}
|
||||
}
|
187
test/hotspot/jtreg/vmTestbase/heapdump/share/common.sh
Normal file
187
test/hotspot/jtreg/vmTestbase/heapdump/share/common.sh
Normal file
@ -0,0 +1,187 @@
|
||||
#!/bin/bash
|
||||
# Copyright (c) 2007, 2018, 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
|
||||
# under the terms of the GNU General Public License version 2 only, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# version 2 for more details (a copy is included in the LICENSE file that
|
||||
# accompanied this code).
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License version
|
||||
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
# or visit www.oracle.com if you need additional information or have any
|
||||
# questions.
|
||||
|
||||
# This script contains useful functions for testing heapdump
|
||||
# feature of VM.
|
||||
|
||||
: ${JAVA:="$TESTJAVA/bin/java"}
|
||||
: ${JAVA_OPTS:="$TESTJAVAOPTS $TESTVMOPTS -cp $TESTCLASSPATH"}
|
||||
: ${CP:="$TESTCLASSPATH"}
|
||||
: ${TEST_CLEANUP:="false"}
|
||||
: ${JMAP:="$TESTJAVA/bin/jmap"}
|
||||
: ${JHSDB:="$TESTJAVA/bin/jhsdb"}
|
||||
|
||||
export PATH=$PATH:$TESTNATIVEPATH
|
||||
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$TESTNATIVEPATH
|
||||
export DYLD_LIBRARY_PATH=$DYLD_LIBRARY_PATH:$TESTNATIVEPATH
|
||||
|
||||
if [ -z "${JAVA}" ]; then
|
||||
echo JAVA variable is not set.
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ -n "${testWorkDir}" ]; then
|
||||
cd ${testWorkDir}
|
||||
fi
|
||||
|
||||
if [ -z "${DUMPBASE}" ]; then
|
||||
DUMPBASE=.
|
||||
fi
|
||||
if [ -z "$DEBUGGER_JAVA_OPTS" ]; then
|
||||
DEBUGGER_JAVA_OPTS="$JAVA_OPTS"
|
||||
fi
|
||||
|
||||
CORE_SUPPORTED=1
|
||||
|
||||
for opt in $DEBUGGER_JAVA_OPTS; do
|
||||
case $opt in
|
||||
-D*)
|
||||
JMAP="$JMAP -J$opt"
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
export CORE_SUPPORTED
|
||||
|
||||
# Verify heap dump
|
||||
# This function starts HprofParser and looks for message "Server is ready."
|
||||
# in output, in which case heap dump is verified.
|
||||
verify_heapdump() {
|
||||
filename=$1
|
||||
shift
|
||||
echo Verifying ${filename}
|
||||
echo ${JAVA} -cp $CP jdk.test.lib.hprof.HprofParser ${filename}
|
||||
${JAVA} -cp $CP jdk.test.lib.hprof.HprofParser ${filename}
|
||||
}
|
||||
|
||||
cleanup() {
|
||||
result="$1"
|
||||
if [ -n "$DUMPFILE" ]; then
|
||||
if [ "$TEST_CLEANUP" != "false" ]; then
|
||||
rm -f "$DUMPFILE"
|
||||
else
|
||||
gzip "$DUMPFILE" || true
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
fail() {
|
||||
message="$1"
|
||||
res=1
|
||||
echo "$message"
|
||||
echo "TEST FAILED"
|
||||
cleanup $res
|
||||
exit 1
|
||||
}
|
||||
|
||||
pass() {
|
||||
message="$1"
|
||||
if [ -n "$message" ]; then
|
||||
echo "$message"
|
||||
fi
|
||||
echo "TEST PASSED"
|
||||
cleanup 0
|
||||
exit 0
|
||||
}
|
||||
|
||||
# Parse VM options that have size argument and return it's value in bytes.
|
||||
# Function applicable to -Xmn, -Xms, -Xms and all possible -XX: options.
|
||||
parse_heap_size() {
|
||||
OPTION=$1
|
||||
SIZE=0
|
||||
MULTIPLIER=0
|
||||
|
||||
# On Solaris sed don't support '+' quantificator, so <smth><smth>* is used.
|
||||
# There is no support for '?' too, so <smth>* is used instead.
|
||||
# Generally speaking, there sed on Solaris support only basic REs.
|
||||
case "$OPTION" in
|
||||
-Xm*)
|
||||
SIZE=`echo $OPTION | sed -e 's#-Xm[xns]\([0-9][0-9]*\).*#\1#'`
|
||||
MULTIPLIER=`echo $OPTION | sed -e 's#-Xm[xns][0-9][0-9]*\([kKmMgG]*\)#\1#'`
|
||||
;;
|
||||
-XX*)
|
||||
SIZE=`echo $OPTION | sed -e 's#[^=][^=]*=\([0-9][0-9]*\).*#\1#'`
|
||||
MULTIPLIER=`echo $OPTION | sed -e 's#[^=][^=]*=[0-9][0-9]*\([kKmMgG]*\)#\1#'`
|
||||
;;
|
||||
esac
|
||||
|
||||
case "$MULTIPLIER" in
|
||||
k|K)
|
||||
SIZE=$(( SIZE * 1024 ))
|
||||
;;
|
||||
m|M)
|
||||
SIZE=$(( SIZE * 1024 * 1024 ))
|
||||
;;
|
||||
g|G)
|
||||
SIZE=$(( SIZE * 1024 * 1024 * 1024 ))
|
||||
;;
|
||||
esac
|
||||
|
||||
echo $SIZE
|
||||
}
|
||||
|
||||
# Derivate max heap size from passed option list.
|
||||
get_max_heap_size() {
|
||||
MaxHeapSize=
|
||||
InitialHeapSize=
|
||||
MaxNewSize=
|
||||
NewSize=
|
||||
OldSize=
|
||||
|
||||
for OPTION in "$@"; do
|
||||
case "$OPTION" in
|
||||
-Xmx*|-XX:MaxHeapSize=*)
|
||||
MaxHeapSize=`parse_heap_size $OPTION`
|
||||
;;
|
||||
-Xms*|-XX:InitialHeapSize=*)
|
||||
InitialHeapSize=`parse_heap_size $OPTION`
|
||||
;;
|
||||
-Xmn*|-XX:MaxNewSize=*)
|
||||
MaxNewSize=`parse_heap_size $OPTION`
|
||||
;;
|
||||
-XX:NewSize=*)
|
||||
NewSize=`parse_heap_size $OPTION`
|
||||
;;
|
||||
-XX:OldSize=*)
|
||||
OldSize=`parse_heap_size $OPTION`
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
if [ -n "$MaxHeapSize" ]; then
|
||||
echo "$MaxHeapSize"
|
||||
elif [ -n "$InitialHeapSize" ]; then
|
||||
echo "$InitialHeapSize"
|
||||
elif [ -n "$MaxNewSize" -a -n "$OldSize" ]; then
|
||||
echo $(( MaxHeapSize + OldSize ))
|
||||
elif [ -n "$NewSize" -a -n "$OldSize" ]; then
|
||||
echo $(( 2 * NewSize + OldSize ))
|
||||
elif [ -n "$OldSize" ]; then
|
||||
echo $(( 2 * OldSize ))
|
||||
elif [ -n "$MaxNewSize" ]; then
|
||||
echo $(( 2 * MaxNewSize ))
|
||||
elif [ -n "$NewSize" ]; then
|
||||
echo $(( 3 * NewSize ))
|
||||
else
|
||||
echo "128M"
|
||||
fi
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user