Skip to content

Commit

Permalink
adding scripts for new code coverage
Browse files Browse the repository at this point in the history
  • Loading branch information
mschoch committed Nov 21, 2014
1 parent 12ec317 commit a313928
Show file tree
Hide file tree
Showing 2 changed files with 91 additions and 0 deletions.
45 changes: 45 additions & 0 deletions docs/merge-coverprofile.go
Original file line number Diff line number Diff line change
@@ -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 changes: 46 additions & 0 deletions docs/project-code-coverage.sh
Original file line number Diff line number Diff line change
@@ -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

0 comments on commit a313928

Please sign in to comment.