1*795d594fSAndroid Build Coastguard Worker#!/bin/bash 2*795d594fSAndroid Build Coastguard Worker# 3*795d594fSAndroid Build Coastguard Worker# Copyright (C) 2017 The Android Open Source Project 4*795d594fSAndroid Build Coastguard Worker# 5*795d594fSAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License"); 6*795d594fSAndroid Build Coastguard Worker# you may not use this file except in compliance with the License. 7*795d594fSAndroid Build Coastguard Worker# You may obtain a copy of the License at 8*795d594fSAndroid Build Coastguard Worker# 9*795d594fSAndroid Build Coastguard Worker# http://www.apache.org/licenses/LICENSE-2.0 10*795d594fSAndroid Build Coastguard Worker# 11*795d594fSAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software 12*795d594fSAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS, 13*795d594fSAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*795d594fSAndroid Build Coastguard Worker# See the License for the specific language governing permissions and 15*795d594fSAndroid Build Coastguard Worker# limitations under the License. 16*795d594fSAndroid Build Coastguard Worker 17*795d594fSAndroid Build Coastguard Workerimport sys 18*795d594fSAndroid Build Coastguard Worker 19*795d594fSAndroid Build Coastguard Worker 20*795d594fSAndroid Build Coastguard Workerdef run(ctx, args): 21*795d594fSAndroid Build Coastguard Worker # Enable lock contention logging. 22*795d594fSAndroid Build Coastguard Worker ctx.default_run(args, runtime_option=["-Xlockprofthreshold:10"]) 23*795d594fSAndroid Build Coastguard Worker 24*795d594fSAndroid Build Coastguard Worker # Run locks-only mode with stack-dump lock profiling. Reduce the number of total operations from 25*795d594fSAndroid Build Coastguard Worker # the default 1000 to 100. 26*795d594fSAndroid Build Coastguard Worker ctx.default_run( 27*795d594fSAndroid Build Coastguard Worker args, 28*795d594fSAndroid Build Coastguard Worker test_args=["--locks-only -o 100"], 29*795d594fSAndroid Build Coastguard Worker runtime_option=[ 30*795d594fSAndroid Build Coastguard Worker "-Xlockprofthreshold:10", "-Xstackdumplockprofthreshold:20" 31*795d594fSAndroid Build Coastguard Worker ]) 32*795d594fSAndroid Build Coastguard Worker 33*795d594fSAndroid Build Coastguard Worker # Do not compare numbers, so replace numbers with 'N'. 34*795d594fSAndroid Build Coastguard Worker ctx.run(fr"sed -i 's/[0-9][0-9]*/N/g' '{args.stdout_file}'") 35*795d594fSAndroid Build Coastguard Worker 36*795d594fSAndroid Build Coastguard Worker # Remove all messages relating to failing to allocate a java-peer for the 37*795d594fSAndroid Build Coastguard Worker # shutdown thread. This can occasionally happen with this test but it is not 38*795d594fSAndroid Build Coastguard Worker # something we really need to worry about here. 39*795d594fSAndroid Build Coastguard Worker ctx.run(fr"sed -i '/Exception creating thread peer:/d' '{args.stderr_file}'") 40