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