minio/pkg/probe/probe_test.go

64 lines
1.7 KiB
Go
Raw Normal View History

2015-08-02 05:38:08 -04:00
/*
* Minio Cloud Storage, (C) 2015 Minio, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package probe_test
2015-08-02 05:38:08 -04:00
import (
"os"
"testing"
2016-02-10 19:40:09 -05:00
"github.com/minio/minio/pkg/probe"
. "gopkg.in/check.v1"
2015-08-02 05:38:08 -04:00
)
func Test(t *testing.T) { TestingT(t) }
type MySuite struct{}
var _ = Suite(&MySuite{})
2015-08-20 01:40:05 -04:00
func testDummy0() *probe.Error {
_, e := os.Stat("this-file-cannot-exit")
2015-08-20 01:40:05 -04:00
return probe.NewError(e)
}
func testDummy1() *probe.Error {
return testDummy0().Trace("DummyTag1")
}
func testDummy2() *probe.Error {
return testDummy1().Trace("DummyTag2")
2015-08-02 05:38:08 -04:00
}
func (s *MySuite) TestProbe(c *C) {
probe.Init() // Set project's root source path.
2016-02-10 19:40:09 -05:00
probe.SetAppInfo("Commit-ID", "7390cc957239")
2015-08-20 01:40:05 -04:00
es := testDummy2().Trace("TopOfStack")
// Uncomment the following Println to visually test probe call trace.
// fmt.Println("Expecting a simulated error here.", es)
c.Assert(es, Not(Equals), nil)
2015-08-02 14:57:47 -04:00
newES := es.Trace()
c.Assert(newES, Not(Equals), nil)
}
func (s *MySuite) TestWrappedError(c *C) {
_, e := os.Stat("this-file-cannot-exit")
2015-08-18 22:30:17 -04:00
es := probe.NewError(e) // *probe.Error
e = probe.WrapError(es) // *probe.WrappedError
_, ok := probe.UnwrapError(e)
c.Assert(ok, Equals, true)
2015-08-02 05:38:08 -04:00
}