Skip to content

Latest commit

 

History

History
78 lines (55 loc) · 2.87 KB

File metadata and controls

78 lines (55 loc) · 2.87 KB

CircleCI Go Report Card GoDoc license

go-deadline

Description

go-deadline is a library to create deadlines for goroutines and programs. This package is used as a safeguard to prevent a goroutine, test, or program from exhausting resources or otherwise running beyond the expected duration of time. You can also use this library for automatically introducing some chaos into your container environment to test failover and network resilience.

Usage

Go

You can import go-deadline as a library with:

import (
  "time"
  "github.com/spatialcurrent/go-deadline/pkg/deadline"
)

You can create a deadline near the start of your program.

func main() {

  ...

  d, err := deadline.New(5*time.Second, deadline.ExitError)
  if err != nil {
    return fmt.Errorf("error creating deadline: %w", err)
  }
  err := d.Start()
  if err != nil {
    return fmt.Errorf("error starting deadline: %w", err)
  }
  // deadline is no running in a separate goroutine

  ...
}

If you do not care to handle errors yourself, you can use the deadline.MustStart function with the default deadline.ExitError function.

func main() {
  ...
  deadline.MustStart(context.Background(), 5*time.Second, deadline.ExitError)
  ...
}

Alternatively, if you wish to post a custom error to stderr, you can provide a custom function as below.

func main() {
  ...
  deadline.MustStart(context.Background(), 5*time.Second, func(ctx context.Context) {
    fmt.Fprintln(os.Stderr, "deadline reached")
    os.Exit(1)
  })
  ...
}

See deadline in GoDoc for further API documentation.

Testing

To run Go tests use make test_go (or bash scripts/test.sh), which runs unit tests, go vet, go vet with shadow, errcheck, ineffassign, staticcheck, and misspell.

Contributing

Spatial Current, Inc. is currently accepting pull requests for this repository. We'd love to have your contributions! Please see Contributing.md for how to get started.

License

This work is distributed under the MIT License. See LICENSE file.