| #!/bin/bash |
| # |
| # Copyright 2021 The Cobalt 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. |
| |
| # Unset the previous test's name and runner function. |
| unset TEST_NAME |
| unset TEST_FILE |
| unset -f run_test |
| |
| TEST_NAME="SuspendResume" |
| TEST_FILE="test.html" |
| |
| function verify_log() { |
| declare -a CrashSignals=("SIGABRT" "SIGBUS" "SIGFPE" "SIGILL" "SIGSEGV" "SIGSYS") |
| |
| for VAL in ${CrashSignals[@]}; do |
| if grep -Eq "Caught signal: ${VAL}" "${1}"; then |
| log "error" "Crash detected" |
| return 1 |
| fi |
| done |
| |
| return 0 |
| } |
| |
| function run_test() { |
| clear_storage |
| |
| LOG="${TEST_NAME}.0.log" |
| start_cobalt "file:///tests/${TEST_FILE}?channel=test" "${LOG}" LOADER --update_check_delay_seconds=1 |
| |
| VAR=1 |
| |
| for i in {1..20} |
| do |
| log "info" "SuspendResume #${VAR}" |
| sleep ${VAR} |
| |
| # suspend |
| kill -s USR1 "${LOADER}" |
| if [[ $? -ne 0 ]]; then |
| log "warning" "Failed to suspend" |
| break |
| fi |
| |
| sleep 1 |
| |
| # resume |
| kill -s CONT "${LOADER}" |
| if [[ $? -ne 0 ]]; then |
| log "warning" "Failed to resume" |
| break |
| fi |
| |
| let "VAR=${VAR}+1" |
| done |
| |
| return $(verify_log "${LOG_PATH}/${LOG}") |
| } |