1
0
mirror of https://github.com/DNSCrypt/dnscrypt-proxy.git synced 2025-01-01 00:57:32 +01:00
dnscrypt-proxy/vendor/github.com/powerman/check
2021-09-24 09:30:49 +02:00
..
.gitattributes Update deps 2021-07-03 10:56:53 +02:00
.gitignore Update deps 2021-07-03 10:56:53 +02:00
.golangci.yml Update deps 2021-07-03 10:56:53 +02:00
check.go powerman update 2021-08-17 16:56:09 +02:00
color_bsd.go Add unit tests for sources.go 2019-11-08 10:17:12 +01:00
color_linux.go Add unit tests for sources.go 2019-11-08 10:17:12 +01:00
color_other.go Add unit tests for sources.go 2019-11-08 10:17:12 +01:00
color_windows.go Add unit tests for sources.go 2019-11-08 10:17:12 +01:00
color.go Update deps 2021-07-03 10:56:53 +02:00
doc.go Update deps 2021-07-03 10:56:53 +02:00
dump.go Update deps 2021-07-03 10:56:53 +02:00
flags.go Update deps 2021-07-03 10:56:53 +02:00
goconvey.go Add unit tests for sources.go 2019-11-08 10:17:12 +01:00
LICENSE Add unit tests for sources.go 2019-11-08 10:17:12 +01:00
README.md Update deps 2021-07-03 10:56:53 +02:00
stats.go Update deps 2021-07-03 10:56:53 +02:00
tools.go Update deps 2021-07-03 10:56:53 +02:00
util.go Add unit tests for sources.go 2019-11-08 10:17:12 +01:00

check GoDoc Go Report Card CircleCI Coverage Status

Helpers to complement Go testing package.

Write tests with ease and fun!

This package is like testify/assert on steroids. :)

Features

  • Compelling output from failed tests:
    • Very easy-to-read dumps for expected and actual values.
    • Same text diff you loved in testify/assert.
    • Also visual diff in GoConvey web UI, if you use it (recommended).
  • Statistics with amount of passed/failed checks.
  • Colored output in terminal.
  • 100% compatible with testing package - check package just provide convenient wrappers for *testing.T methods and doesn't introduce new concepts like BDD, custom test suite or unusual execution flow.
  • All checks you may ever need! :)
  • Very easy to add your own check functions.
  • Concise, handy and consistent API, without dot-import!

Quickstart

Just wrap each (including subtests) *testing.T using check.T() and write tests as usually with testing package. Call new methods provided by this package to have more clean/concise test code and cool dump/diff.

import "github.com/powerman/check"

func TestSomething(tt *testing.T) {
	t := check.T(tt)
	t.Equal(2, 2)
	t.Log("You can use new t just like usual *testing.T")
	t.Run("Subtests/Parallel example", func(tt *testing.T) {
		t := check.T(tt)
		t.Parallel()
		t.NotEqual(2, 3, "should not be 3!")
		obj, err := NewObj()
		if t.Nil(err) {
			t.Match(obj.field, `^\d+$`)
		}
	})
}

To get optional statistics about executed checkers add:

func TestMain(m *testing.M) { check.TestMain(m) }

When use goconvey tool, to get nice diff in web UI add:

import _ "github.com/smartystreets/goconvey/convey"

Installation

Require Go 1.9.

go get github.com/powerman/check

TODO

  • Doc:
    • Add testable examples.
    • Show how text diff and stats looks like (both text and screenshot with colors).
    • Show how goconvey diff looks like.
  • Questionable:
    • Support custom checkers from gocheck etc.?
    • Provide a way to force binary dump for utf8.Valid string/[]byte?
    • Count skipped tests (will have to overload Skip, Skipf, SkipNow)?
  • Complicated:
    • Show line of source_test.go with failed test (like gocheck).
    • Auto-detect missed t:=check.T(tt) - try to intercept Run() and Parallel() for detecting using wrong t (looks like golangci-lint's tparallel catch at least Parallel() case).