frp/vendor/golang.org/x/net/context/withtimeout_test.go

32 lines
830 B
Go
Raw Normal View History

2017-11-01 08:21:57 +00:00
// Copyright 2014 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.
package context_test
import (
"fmt"
"time"
"golang.org/x/net/context"
)
2018-05-04 10:37:43 +00:00
// This example passes a context with a timeout to tell a blocking function that
// it should abandon its work after the timeout elapses.
2017-11-01 08:21:57 +00:00
func ExampleWithTimeout() {
// Pass a context with a timeout to tell a blocking function that it
// should abandon its work after the timeout elapses.
2018-05-04 10:37:43 +00:00
ctx, cancel := context.WithTimeout(context.Background(), 50*time.Millisecond)
defer cancel()
2017-11-01 08:21:57 +00:00
select {
2018-05-04 10:37:43 +00:00
case <-time.After(1 * time.Second):
2017-11-01 08:21:57 +00:00
fmt.Println("overslept")
case <-ctx.Done():
fmt.Println(ctx.Err()) // prints "context deadline exceeded"
}
2018-05-04 10:37:43 +00:00
2017-11-01 08:21:57 +00:00
// Output:
// context deadline exceeded
}