adding scripts for new code coverage
This commit is contained in:
parent
12ec3173fa
commit
a313928be2
45
docs/merge-coverprofile.go
Normal file
45
docs/merge-coverprofile.go
Normal file
@ -0,0 +1,45 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"bufio"
|
||||
"fmt"
|
||||
"os"
|
||||
"strconv"
|
||||
"strings"
|
||||
)
|
||||
|
||||
func main() {
|
||||
|
||||
modeline := ""
|
||||
blocks := map[string]int{}
|
||||
scanner := bufio.NewScanner(os.Stdin)
|
||||
for scanner.Scan() {
|
||||
line := scanner.Text()
|
||||
if !strings.HasPrefix(line, "mode:") {
|
||||
lastSpace := strings.LastIndex(line, " ")
|
||||
prefix := line[0:lastSpace]
|
||||
suffix := line[lastSpace+1:]
|
||||
count, err := strconv.Atoi(suffix)
|
||||
if err != nil {
|
||||
fmt.Errorf("error parsing count: %v", err)
|
||||
continue
|
||||
}
|
||||
existingCount, exists := blocks[prefix]
|
||||
if exists {
|
||||
blocks[prefix] = existingCount + count
|
||||
} else {
|
||||
blocks[prefix] = count
|
||||
}
|
||||
} else if modeline == "" {
|
||||
modeline = line
|
||||
}
|
||||
}
|
||||
if err := scanner.Err(); err != nil {
|
||||
fmt.Fprintln(os.Stderr, "reading standard input:", err)
|
||||
}
|
||||
|
||||
fmt.Println(modeline)
|
||||
for k, v := range blocks {
|
||||
fmt.Printf("%s %d\n", k, v)
|
||||
}
|
||||
}
|
46
docs/project-code-coverage.sh
Executable file
46
docs/project-code-coverage.sh
Executable file
@ -0,0 +1,46 @@
|
||||
#!/bin/bash
|
||||
|
||||
echo "mode: count" > acc.out
|
||||
for Dir in . $(find ./* -maxdepth 10 -type d );
|
||||
do
|
||||
if ls $Dir/*.go &> /dev/null;
|
||||
then
|
||||
returnval=`go test -coverprofile=profile.out -covermode=count $Dir`
|
||||
echo ${returnval}
|
||||
if [[ ${returnval} != *FAIL* ]]
|
||||
then
|
||||
if [ -f profile.out ]
|
||||
then
|
||||
cat profile.out | grep -v "mode: count" >> acc.out
|
||||
fi
|
||||
else
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
done
|
||||
|
||||
# collect integration test coverage
|
||||
echo "mode: count" > integration-acc.out
|
||||
INTPACKS=`go list ./... | grep -v utils | xargs | sed 's/ /,/g'`
|
||||
returnval=`go test -coverpkg=$INTPACKS -coverprofile=profile.out -covermode=count ./test`
|
||||
if [[ ${returnval} != *FAIL* ]]
|
||||
then
|
||||
if [ -f profile.out ]
|
||||
then
|
||||
cat profile.out | grep -v "mode: count" >> integration-acc.out
|
||||
fi
|
||||
else
|
||||
exit 1
|
||||
fi
|
||||
|
||||
cat acc.out integration-acc.out | go run docs/merge-coverprofile.go > merged.out
|
||||
|
||||
if [ -n "$COVERALLS" ]
|
||||
then
|
||||
goveralls -service drone.io -coverprofile=merged.out -repotoken $COVERALLS
|
||||
fi
|
||||
|
||||
rm -rf ./profile.out
|
||||
rm -rf ./acc.out
|
||||
rm -rf ./integration-acc.out
|
||||
rm -rf ./merged.out
|
Loading…
Reference in New Issue
Block a user