Commit 3b87d68a authored by Rob Pike's avatar Rob Pike

testing: document examples

The package documentation did not mention them.
They were described only in godoc for gotest, and that's going away.

R=golang-dev, rsc, adg
CC=golang-dev
https://golang.org/cl/5539079
parent 2ebf0de2
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
// license that can be found in the LICENSE file. // license that can be found in the LICENSE file.
// Package testing provides support for automated testing of Go packages. // Package testing provides support for automated testing of Go packages.
// It is intended to be used in concert with the ``gotest'' utility, which automates // It is intended to be used in concert with the ``go test'' command, which automates
// execution of any function of the form // execution of any function of the form
// func TestXxx(*testing.T) // func TestXxx(*testing.T)
// where Xxx can be any alphanumeric string (but the first letter must not be in // where Xxx can be any alphanumeric string (but the first letter must not be in
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
// fmt.Sprintf("hello") // fmt.Sprintf("hello")
// } // }
// } // }
//
// The benchmark package will vary b.N until the benchmark function lasts // The benchmark package will vary b.N until the benchmark function lasts
// long enough to be timed reliably. The output // long enough to be timed reliably. The output
// testing.BenchmarkHello 10000000 282 ns/op // testing.BenchmarkHello 10000000 282 ns/op
...@@ -36,6 +37,33 @@ ...@@ -36,6 +37,33 @@
// big.Len() // big.Len()
// } // }
// } // }
//
// The package also runs and verifies example code. Example functions
// include an introductory comment that is compared with the standard output
// of the function when the tests are run, as in this example of an example:
//
// // hello
// func ExampleHello() {
// fmt.Println("hello")
// }
//
// Example functions without comments are compiled but not executed.
//
// The naming convention to declare examples for a function F, a type T and
// method M on type T are:
//
// func ExampleF() { ... }
// func ExampleT() { ... }
// func ExampleT_M() { ... }
//
// Multiple example functions for a type/function/method may be provided by
// appending a distinct suffix to the name. The suffix must start with a
// lower-case letter.
//
// func ExampleF_suffix() { ... }
// func ExampleT_suffix() { ... }
// func ExampleT_M_suffix() { ... }
//
package testing package testing
import ( import (
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment