logger_test.go 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. // Copyright 2017 Unknwon
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License"): you may
  4. // not use this file except in compliance with the License. You may obtain
  5. // a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  11. // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  12. // License for the specific language governing permissions and limitations
  13. // under the License.
  14. package clog
  15. import (
  16. "testing"
  17. . "github.com/smartystreets/goconvey/convey"
  18. )
  19. func Test_Register(t *testing.T) {
  20. Convey("Register with nil function", t, func() {
  21. defer func() {
  22. err := recover()
  23. So(err, ShouldNotBeNil)
  24. So(err, ShouldEqual, "clog: register function is nil")
  25. }()
  26. Register("test", nil)
  27. })
  28. Convey("Register duplicated mode", t, func() {
  29. defer func() {
  30. err := recover()
  31. So(err, ShouldNotBeNil)
  32. So(err, ShouldEqual, "clog: register duplicated mode 'test'")
  33. }()
  34. Register("test", newConsole)
  35. Register("test", newConsole)
  36. })
  37. Convey("Create non-registered logger", t, func() {
  38. err := New(MODE("404"), nil)
  39. So(err, ShouldNotBeNil)
  40. So(err.Error(), ShouldContainSubstring, "unknown mode")
  41. })
  42. }