...
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