/usr/share/gocode/src/github.com/jacobsa/ogletest/test_info.go is in golang-github-jacobsa-ogletest-dev 0.0~git20150610-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 | // Copyright 2011 Aaron Jacobs. All Rights Reserved.
// Author: aaronjjacobs@gmail.com (Aaron Jacobs)
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package ogletest
import (
"sync"
"golang.org/x/net/context"
"github.com/jacobsa/oglemock"
)
// TestInfo represents information about a currently running or previously-run
// test.
type TestInfo struct {
// A mock controller that is set up to report errors to the ogletest test
// runner. This can be used for setting up mock expectations and handling
// mock calls. The Finish method should not be run by the user; ogletest will
// do that automatically after the test's TearDown method is run.
//
// Note that this feature is still experimental, and is subject to change.
MockController oglemock.Controller
// A context that can be used by tests for long-running operations. In
// particular, this enables conveniently tracing the execution of a test
// function with reqtrace.
Ctx context.Context
// A mutex protecting shared state.
mu sync.RWMutex
// A set of failure records that the test has produced.
//
// GUARDED_BY(mu)
failureRecords []FailureRecord
}
// currentlyRunningTest is the state for the currently running test, if any.
var currentlyRunningTest *TestInfo
// newTestInfo creates a valid but empty TestInfo struct.
func newTestInfo() (info *TestInfo) {
info = &TestInfo{}
info.MockController = oglemock.NewController(&testInfoErrorReporter{info})
info.Ctx = context.Background()
return
}
// testInfoErrorReporter is an oglemock.ErrorReporter that writes failure
// records into a test info struct.
type testInfoErrorReporter struct {
testInfo *TestInfo
}
func (r *testInfoErrorReporter) ReportError(
fileName string,
lineNumber int,
err error) {
r.testInfo.mu.Lock()
defer r.testInfo.mu.Unlock()
record := FailureRecord{
FileName: fileName,
LineNumber: lineNumber,
Error: err.Error(),
}
r.testInfo.failureRecords = append(r.testInfo.failureRecords, record)
}
func (r *testInfoErrorReporter) ReportFatalError(
fileName string,
lineNumber int,
err error) {
r.ReportError(fileName, lineNumber, err)
AbortTest()
}
|