...

Text file src/github.com/sigstore/rekor/tests/e2e-test.sh

Documentation: github.com/sigstore/rekor/tests

     1#!/usr/bin/env bash
     2#
     3# Copyright 2021 The Sigstore Authors.
     4#
     5# Licensed under the Apache License, Version 2.0 (the "License");
     6# you may not use this file except in compliance with the License.
     7# You may obtain a copy of the License at
     8#
     9#     http://www.apache.org/licenses/LICENSE-2.0
    10#
    11# Unless required by applicable law or agreed to in writing, software
    12# distributed under the License is distributed on an "AS IS" BASIS,
    13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    14# See the License for the specific language governing permissions and
    15# limitations under the License.
    16
    17set -e
    18testdir=$(dirname "$0")
    19
    20docker_compose="docker compose -f docker-compose.yml -f docker-compose.test.yml"
    21if ! ${docker_compose} version >/dev/null 2>&1; then
    22    docker_compose="docker-compose -f docker-compose.yml -f docker-compose.test.yml"
    23fi
    24
    25rm -f /tmp/rekor-*.cov
    26
    27echo "installing gocovmerge"
    28make gocovmerge
    29
    30echo "building test-only containers"
    31docker build -t gcp-pubsub-emulator -f Dockerfile.pubsub-emulator .
    32
    33echo "starting services"
    34${docker_compose} up -d --build
    35
    36echo "building CLI and server"
    37go test -c ./cmd/rekor-cli -o rekor-cli -cover -covermode=count -coverpkg=./...
    38go test -c ./cmd/rekor-server -o rekor-server -covermode=count -coverpkg=./...
    39
    40count=0
    41
    42echo "waiting up to 2 min for system to start"
    43until [ $(${docker_compose} ps | \
    44   grep -E "(rekor[-_]mysql|rekor[-_]redis|rekor[-_]rekor-server|rekor[-_]gcp-pubsub-emulator)" | \
    45   grep -c "(healthy)" ) == 4 ];
    46do
    47    if [ $count -eq 24 ]; then
    48       echo "! timeout reached"
    49       exit 1
    50    else
    51       echo -n "."
    52       sleep 5
    53       let 'count+=1'
    54    fi
    55done
    56
    57echo
    58echo "running tests"
    59REKORTMPDIR="$(mktemp -d -t rekor_test.XXXXXX)"
    60touch $REKORTMPDIR.rekor.yaml
    61trap "rm -rf $REKORTMPDIR" EXIT
    62if ! REKORTMPDIR=$REKORTMPDIR go test -tags=e2e ./tests/ -run TestIssue1308; then
    63   ${docker_compose} logs --no-color > /tmp/docker-compose.log
    64   exit 1
    65fi
    66if ! REKORTMPDIR=$REKORTMPDIR PUBSUB_EMULATOR_HOST=localhost:8085 go test -tags=e2e ./tests/; then 
    67   ${docker_compose} logs --no-color > /tmp/docker-compose.log
    68   exit 1
    69fi
    70if ${docker_compose} logs --no-color | grep -q "panic: runtime error:" ; then
    71   # if we're here, we found a panic
    72   echo "Failing due to panics detected in logs"
    73   ${docker_compose} logs --no-color > /tmp/docker-compose.log
    74   exit 1
    75fi
    76
    77echo "generating code coverage"
    78${docker_compose} restart rekor-server
    79
    80if ! docker cp $(docker ps -aqf "name=rekor_rekor-server" -f "name=rekor-rekor-server"):/go/rekor-server.cov /tmp/rekor-server.cov ; then
    81   # failed to copy code coverage report from server
    82   echo "Failed to retrieve server code coverage report"
    83   ${docker_compose} logs --no-color > /tmp/docker-compose.log
    84   exit 1
    85fi
    86
    87# merging coverage reports and filtering out /pkg/generated from final report
    88hack/tools/bin/gocovmerge /tmp/rekor-*.cov | grep -v "/pkg/generated/" > /tmp/rekor-merged.cov
    89echo "code coverage $(go tool cover -func=/tmp/rekor-merged.cov | grep -E '^total\:' | sed -E 's/\s+/ /g')"

View as plain text