mirror of
https://github.com/golang/go
synced 2024-11-18 15:04:44 -07:00
e77366c32d
Given x() panic(1) y() the y should not show as covered. Fixes #10185 Change-Id: Iec61f1b096a888e6727be5f4526508654f5d3c91 Reviewed-on: https://go-review.googlesource.com/8140 Reviewed-by: Robert Griesemer <gri@golang.org>
113 lines
2.8 KiB
Go
113 lines
2.8 KiB
Go
// Copyright 2013 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// Test runner for coverage test. This file is not coverage-annotated; test.go is.
|
|
// It knows the coverage counter is called "coverTest".
|
|
|
|
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
)
|
|
|
|
func main() {
|
|
testAll()
|
|
verify()
|
|
}
|
|
|
|
type block struct {
|
|
count uint32
|
|
line uint32
|
|
}
|
|
|
|
var counters = make(map[block]bool)
|
|
|
|
// check records the location and expected value for a counter.
|
|
func check(line, count uint32) {
|
|
b := block{
|
|
count,
|
|
line,
|
|
}
|
|
counters[b] = true
|
|
}
|
|
|
|
// checkVal is a version of check that returns its extra argument,
|
|
// so it can be used in conditionals.
|
|
func checkVal(line, count uint32, val int) int {
|
|
b := block{
|
|
count,
|
|
line,
|
|
}
|
|
counters[b] = true
|
|
return val
|
|
}
|
|
|
|
var PASS = true
|
|
|
|
// verify checks the expected counts against the actual. It runs after the test has completed.
|
|
func verify() {
|
|
for b := range counters {
|
|
got, index := count(b.line)
|
|
if b.count == anything && got != 0 {
|
|
got = anything
|
|
}
|
|
if got != b.count {
|
|
fmt.Fprintf(os.Stderr, "test_go:%d expected count %d got %d [counter %d]\n", b.line, b.count, got, index)
|
|
PASS = false
|
|
}
|
|
}
|
|
verifyPanic()
|
|
if !PASS {
|
|
fmt.Fprintf(os.Stderr, "FAIL\n")
|
|
os.Exit(2)
|
|
}
|
|
}
|
|
|
|
// verifyPanic is a special check for the known counter that should be
|
|
// after the panic call in testPanic.
|
|
func verifyPanic() {
|
|
if coverTest.Count[panicIndex-1] != 1 {
|
|
// Sanity check for test before panic.
|
|
fmt.Fprintf(os.Stderr, "bad before panic")
|
|
PASS = false
|
|
}
|
|
if coverTest.Count[panicIndex] != 0 {
|
|
fmt.Fprintf(os.Stderr, "bad at panic: %d should be 0\n", coverTest.Count[panicIndex])
|
|
PASS = false
|
|
}
|
|
if coverTest.Count[panicIndex+1] != 1 {
|
|
fmt.Fprintf(os.Stderr, "bad after panic")
|
|
PASS = false
|
|
}
|
|
}
|
|
|
|
// count returns the count and index for the counter at the specified line.
|
|
func count(line uint32) (uint32, int) {
|
|
// Linear search is fine. Choose perfect fit over approximate.
|
|
// We can have a closing brace for a range on the same line as a condition for an "else if"
|
|
// and we don't want that brace to steal the count for the condition on the "if".
|
|
// Therefore we test for a perfect (lo==line && hi==line) match, but if we can't
|
|
// find that we take the first imperfect match.
|
|
index := -1
|
|
indexLo := uint32(1e9)
|
|
for i := range coverTest.Count {
|
|
lo, hi := coverTest.Pos[3*i], coverTest.Pos[3*i+1]
|
|
if lo == line && line == hi {
|
|
return coverTest.Count[i], i
|
|
}
|
|
// Choose the earliest match (the counters are in unpredictable order).
|
|
if lo <= line && line <= hi && indexLo > lo {
|
|
index = i
|
|
indexLo = lo
|
|
}
|
|
}
|
|
if index == -1 {
|
|
fmt.Fprintln(os.Stderr, "cover_test: no counter for line", line)
|
|
PASS = false
|
|
return 0, 0
|
|
}
|
|
return coverTest.Count[index], index
|
|
}
|