mirror of
https://github.com/vacp2p/linea-besu.git
synced 2026-01-08 04:33:56 -05:00
Container verification step in release process automated with the container verify GitHub workflow. New workflow is triggered at the end of the release workflow which will check the release container images starts successfully. Verification test only checks container starts and reach the Ethereum main loop Signed-off-by: Chaminda Divitotawela <cdivitotawela@gmail.com>
71 lines
2.2 KiB
Bash
71 lines
2.2 KiB
Bash
#!/bin/bash
|
|
##
|
|
## Copyright contributors to Hyperledger Besu.
|
|
##
|
|
## 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.
|
|
##
|
|
## SPDX-License-Identifier: Apache-2.0
|
|
##
|
|
|
|
CONTAINER_NAME=${CONTAINER_NAME:-besu}
|
|
VERSION=${VERSION}
|
|
TAG=${TAG}
|
|
CHECK_LATEST=${CHECK_LATEST}
|
|
RETRY=${RETRY:-10}
|
|
SLEEP=${SLEEP:-5}
|
|
|
|
# Helper function to throw error
|
|
log_error() {
|
|
echo "::error $1"
|
|
exit 1
|
|
}
|
|
|
|
# Check container is in running state
|
|
_RUN_STATE=$(docker inspect --type=container -f={{.State.Status}} ${CONTAINER_NAME})
|
|
if [[ "${_RUN_STATE}" != "running" ]]
|
|
then
|
|
log_error "container is not running"
|
|
fi
|
|
|
|
# Check for specific log message in container logs to verify besu started
|
|
_SUCCESS=false
|
|
while [[ ${_SUCCESS} != "true" && $RETRY -gt 0 ]]
|
|
do
|
|
docker logs ${CONTAINER_NAME} | grep -q "Ethereum main loop is up" && {
|
|
_SUCCESS=true
|
|
continue
|
|
}
|
|
echo "Waiting for the besu to start. Remaining retries $RETRY ..."
|
|
RETRY=$(expr $RETRY - 1)
|
|
sleep $SLEEP
|
|
done
|
|
|
|
# Log entry does not present after all retries, fail the script with a message
|
|
if [[ ${_SUCCESS} != "true" ]]
|
|
then
|
|
docker logs --tail=100 ${CONTAINER_NAME}
|
|
log_error "could not find the log message 'Ethereum main loop is up'"
|
|
else
|
|
echo "Besu container started and entered main loop"
|
|
fi
|
|
|
|
# For the latest tag check the version match
|
|
if [[ ${TAG} == "latest" && ${CHECK_LATEST} == "true" ]]
|
|
then
|
|
_VERSION_IN_LOG=$(docker logs ${CONTAINER_NAME} | grep "#" | grep "Besu version" | cut -d " " -f 4 | sed 's/\s//g')
|
|
echo "Extracted version from logs [$_VERSION_IN_LOG]"
|
|
if [[ "$_VERSION_IN_LOG" != "${VERSION}" ]]
|
|
then
|
|
log_error "version [$_VERSION_IN_LOG] extracted from container logs does not match the expected version [${VERSION}]"
|
|
else
|
|
echo "Latest Besu container version matches"
|
|
fi
|
|
fi
|