#!/bin/bash #------------------------------------------------------------------------------ # Copyright (c) Perforce Software, Inc., 2007-2014. All rights reserved # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are met: # # 1 Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the distribution. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL PERFORCE # SOFTWARE, INC. BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON # ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR # TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF # THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH # DAMAGE. #------------------------------------------------------------------------------ LOG=$LOGS/p4verify.log STATUS="OK: All scanned depots verified OK." declare -i EXIT_CODE=0 P4="$P4BIN -p ${P4PORT} -u $P4USER" /p4/common/bin/p4login echo If there are errors in this log, contact support@perforce.com > $LOG # Verify all depots of all types except 'remote' and 'archive'. for d in `$P4 -s depots|grep "^info: Depot " |\ grep -v --perl-regexp "^info: Depot \S+ \d{4}\/\d{2}\/\d{2} (remote|archive|unload) " |\ cut -d ' ' -f 3`; do echo === Started verify of //$d/... at $(date). >> $LOG echo $P4 -s verify -q //$d/... >> $LOG if [[ "${P4REPLICA}" == "FALSE" ]]; then $P4 -s verify -q //$d/... >> $LOG 2>&1 else $P4 -s verify -q -t //$d/... >> $LOG 2>&1 fi if [[ $? -ne 0 ]]; then STATUS="Error: Verify attempt failed. Review the log [$LOG]." EXIT_CODE=1 fi done for d in `$P4 depots | grep unload | cut -d " " -f 2`; do echo === Started verify of //$d/... at $(date). >> $LOG echo $P4 -s verify -U -q //$d/... >> $LOG if [[ "${P4REPLICA}" == "FALSE" ]]; then $P4 -s verify -U -q //$d/... >> $LOG 2>&1 else $P4 -s verify -U -q -t //$d/... >> $LOG 2>&1 fi if [[ $? -ne 0 ]]; then STATUS="Error: Verify attempt failed. Review the log [$LOG]." EXIT_CODE=1 fi done if [[ $EXIT_CODE -eq 0 ]]; then if [[ -n "$(grep BAD! $LOG)" || -n "$(grep MISSING! $LOG)" || -n "$(grep p4\ help\ max $LOG)" ]]; then STATUS="Warning: Verify errors detected. Review the log [$LOG]." EXIT_CODE=1 fi fi echo Completed verifications at $(date). >> $LOG $MAIL -s "$HOSTNAME $P4SERVER P4Verify Log ($STATUS)" $MAILTO < $LOG exit $EXIT_CODE
# | Change | User | Description | Committed | |
---|---|---|---|---|---|
#3 | 15789 | alan_petersen | Merging latest revision | ||
#2 | 15465 | alan_petersen | Merging using sdp_alan_petersen | ||
#1 | 10151 | alan_petersen |
Populate //guest/alan_petersen/sdp/... from //guest/perforce_software/sdp/.... |
||
//guest/perforce_software/sdp/main/Server/Unix/p4/common/bin/p4verify.sh | |||||
#1 | 10148 | C. Thomas Tyler | Promoted the Perforce Server Deployment Package to The Workshop. |