test_script-recover_edge_2.sh #1

  • //
  • p4-sdp/
  • dev_rebrand2/
  • test/
  • bsw/
  • test_script-recover_edge_2.sh
  • View
  • Commits
  • Open Download .zip Download (4 KB)
#!/bin/bash
set -u

declare ThisScript="${0##*/}"
declare Version=1.0.3
declare -i ErrorCount=0
declare -i Debug=${SDP_DEBUG:-0}
declare EdgeHost=syd-helix-04
declare -i LocalLogCount=0
declare -a LocalLogList
declare -i EdgeLogCount=0
declare -a EdgeLogList
declare EdgeClientsFile=
declare UUID=

function msg () { echo -e "$*"; }
function dbg () { [[ "$Debug" -eq 0 ]] || msg "DEBUG: $*"; }
function errmsg () { msg "\\nError: ${1:-Unknown Error}\\n"; ErrorCount+=1; }
function bail () { errmsg "${1:-Unknown Error}"; exit "$ErrorCount"; }

msg "Start test [$ThisScript v$Version]: Do serial edge dump."

# Setup: Create site config dir if needed
mkdir -p /p4/common/site/config
ssh "$EdgeHost" mkdir -p /p4/common/site/config

msg "Configure for serial checkpoint ops on commit and edge."

{
   echo export DO_PARALLEL_CHECKPOINTS=4
   echo KEEPCKPS=2
   echo KEEPJNLS=2
   echo KEEPCKPS=2
} > /p4/common/site/config/p4_1.vars.local

rsync /p4/common/site/config/p4_1.vars.local "$EdgeHost":/p4/common/site/config/p4_1.vars.local ||\
   errmsg "Failed to copy /p4/common/site/config/p4_1.vars.local."

msg "Create and flush clients on the edge."
UUID=$(uuidgen|cut -c1-6)
p4 -p syd-helix-04:1999 login bruno
p4 -p syd-helix-04:1999 -u bruno --field Root=/p4/1/tmp/Test1.$UUID client -S //jam/dev2.3 -o Test1.$UUID | p4 -s -p syd-helix-04:1999 -u bruno client -i
p4 -p syd-helix-04:1999 -u bruno -c Test1.$UUID flush -q
p4 -p syd-helix-04:1999 -u bruno --field Root=/p4/1/tmp/Test2.$UUID client -S //jam/main -o Test2.$UUID | p4 -s -p syd-helix-04:1999 -u bruno client -i
p4 -p syd-helix-04:1999 -u bruno -c Test2.$UUID flush -q

msg "Rotate journal on commit."
rotate_journal.sh 1
LocalLogList[LocalLogCount]="/p4/1/logs/checkpoint.log"
LocalLogCount+=1

msg "Creating serial edge dump on commit."
msg "Running: edge_dump.sh 1 p4d_edge_syd"
edge_dump.sh 1 p4d_edge_syd

LocalLogList[LocalLogCount]="/p4/1/logs/edge_dump.log"
LocalLogCount+=1

msg "Copying /p4/1/checkpoints to edge server."
rsync -a /p4/1/checkpoints/ syd-helix-04:/p4/1/checkpoints ||\
   errmsg "Could not do: rsync -a /p4/1/checkpoints/ syd-helix-04:/p4/1/checkpoints"

# Get the latest MD5 from the parallel dump just created above, which will
# end in *.md5. The checkpoint directory has the same name sans the .md5 suffix.
EdgeSeedMD5=$(ls -t /p4/1/checkpoints/p4_1.edge_syd.seed.*.md5 | head -1)
EdgeSeed="${EdgeSeedMD5%.md5}"

[[ -d "$EdgeSeed" ]] || errmsg "Could not find checkpoint directory: $EdgeSeed"

msg "\\nRunning: ssh $EdgeHost /p4/common/bin/recover_edge.sh 1 ${EdgeSeed}"
ssh "$EdgeHost" /p4/common/bin/recover_edge.sh 1 ${EdgeSeed} ||\
   errmsg "Remote call to recover_edge.sh indicated an error."

EdgeLogList[EdgeLogCount]="/p4/1/logs/recover_edge.log"
EdgeLogCount+=1

msg "\\nChecking that clients created earlier are still here after recovery."
EdgeClientsFile=/p4/1/tmp/edge_clients.txt
p4 -p syd-helix-04:1999 login bruno
p4 -p syd-helix-04:1999 -u bruno clients > "$EdgeClientsFile"
cat "$EdgeClientsFile"
grep Test1.$UUID "$EdgeClientsFile" ||\
   errmsg "Did not see client Test1.$UUID after edge recovery."
grep Test2.$UUID "$EdgeClientsFile" ||\
   errmsg "Did not see client Test2.$UUID after edge recovery."

msg "Checking for syntax and unbound errors in scripts used in this test."
for log in "${LocalLogList[@]}"; do
   msg "Checking for 'unbound variable' in: $log"
   grep ':unbound variable' "$log" && \
      errmsg "Found 'unbound variable' error in $log"
   msg "Checking for 'syntax error' in: $log"
   grep ':syntax error' "$log" && \
      errmsg "Found 'syntax error' in $log"
done

msg "Checking for syntax and unbound errors in scripts used in this test on edge host."
for log in "${EdgeLogList[@]}"; do
   msg "Checking for 'unbound variable' in: $EdgeHost:$log"
   ssh -q "$EdgeHost" "grep ':unbound variable' $log" && \
      errmsg "Found 'unbound variable' error in $log"
   msg "Checking for 'syntax error' in: $EdgeHost:$log"
   ssh -q "$EdgeHost" "grep ':syntax error' $log" && \
      errmsg "Found 'syntax error' in $log"
done

exit "$ErrorCount"
# Change User Description Committed
#1 31646 C. Thomas Tyler Populate -r -o -S //p4-sdp/dev_rebrand2.
//p4-sdp/dev/test/bsw/test_script-recover_edge_2.sh
#2 31574 C. Thomas Tyler Merged SDP 2024.2 Patch 4 from Classic to Streams.
p4 merge -b SDP_Classic_to_Streams
#1 31397 C. Thomas Tyler Populate -b SDP_Classic_to_Streams -s //guest/perforce_software/sdp/...@31368.
//guest/perforce_software/sdp/dev/test/bsw/test_script-recover_edge_2.sh
#1 30649 C. Thomas Tyler Added more tests for recover_edge.sh and related scripts, and improved
auditability the first test script for recover_edge.sh.