#!/bin/bash # # Copyright 2017 The Bazel Authors. All rights reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # # discard_graph_edges_lib.sh: functions needed by discard_graph_edges_test.sh STARTUP_FLAGS="--batch" BUILD_FLAGS="--discard_analysis_cache --notrack_incremental_state" function extract_histogram_count() { local histofile="$1" local item="$2" # We can't use + here because Macs don't recognize it as a special character # by default. grep "$item" "$histofile" \ | sed -e 's/^ *[0-9][0-9]*: *\([0-9][0-9]*\) .*$/\1/' \ || fail "Couldn't get item from $histofile" } function run_test_actions_deleted_after_execution() { readonly local product="$1" readonly local javabase="$2" readonly local get_pid_expression="$3" readonly local extra_build_arg="$4" rm -rf histodump mkdir -p histodump || fail "Couldn't create directory" readonly local server_pid_file="$TEST_TMPDIR/server_pid.txt" # Use fifo objects to block the execution phase of the dummy build. readonly local exec_has_started_fifo="$TEST_TMPDIR/exec_fifo" readonly local unblock_exec_fifo="$TEST_TMPDIR/wait_fifo" # Create the chain of four genrules, using fifos to block execution cat > histodump/BUILD < /dev/null; ' + 'touch \$@' ) EOF for i in $(seq 1 3); do # Outputs a histogram of the server's memory, logging failures. iminus=$((i-1)) cat >> histodump/BUILD < ' + ' \$(location histo.${i}) && break ;' + 'done ' + '|| echo "server_pid in genrule: \$\$server_pid"' ) EOF done mkfifo "$unblock_exec_fifo" "$exec_has_started_fifo" local readonly histo_root="$("$product" info \ "${PRODUCT_NAME:-$product}-genfiles" 2> /dev/null)/histodump/histo." "$product" clean >& "$TEST_log" || fail "Couldn't clean" readonly local explicit_server_pid="$("$product" $STARTUP_FLAGS info \ server_pid)" "$product" $STARTUP_FLAGS build --show_timestamps $BUILD_FLAGS \ $extra_build_arg //histodump:action3 >> "$TEST_log" 2>&1 & subshell_pid="$!" # We will only get past the following line once execution has started, # at which point we can look for the pid. cat "$exec_has_started_fifo" > /dev/null # We plan to remove batch mode from the relevant flags for discarding # incrementality state. In the interim, tests that are not in batch mode # explicitly pass --nobatch, so we can use it as a signal. if [[ "$STARTUP_FLAGS" =~ "--nobatch" ]]; then server_pid="$explicit_server_pid" else if [[ -z "$get_pid_expression" ]]; then server_pid="$subshell_pid" else server_pid="$($get_pid_expression)" fi fi echo "server_pid in main thread is ${server_pid}" # >> "$TEST_log" echo "$server_pid" > "$server_pid_file" echo "Finished writing pid to fifo at " >> "$TEST_log" date >> "$TEST_log" # Now that all of the above is finished, unblock the execution of action0 echo "" > "$unblock_exec_fifo" # Wait for the build to finish. wait "$subshell_pid" || fail "Bazel command failed" local genrule_action_count=100 for i in $(seq 1 3); do local histo_file="$histo_root$i" local new_genrule_action_count="$(extract_histogram_count "$histo_file" \ "GenRuleAction$")" if [[ "$new_genrule_action_count" -ge "$genrule_action_count" ]]; then cat "$histo_file" >> "$TEST_log" fail "Number of genrule actions did not decrease: $new_genrule_action_count vs. $genrule_action_count" fi if [[ -z "$new_genrule_action_count" ]]; then cat "$histo_file" >> "$TEST_log" fail "No genrule actions? Class may have been renamed" fi genrule_action_count="$new_genrule_action_count" done }