func Test_InjectorSetParent(t *testing.T) { injector := inject.New() injector.MapTo("another dep", (*SpecialString)(nil)) injector2 := inject.New() injector2.SetParent(injector) expect(t, injector2.GetVal(inject.InterfaceOf((*SpecialString)(nil))).IsValid(), true) }
func Test_InjectorInvoke(t *testing.T) { injector := inject.New() expect(t, injector == nil, false) dep := "some dependency" injector.Map(dep) dep2 := "another dep" injector.MapTo(dep2, (*SpecialString)(nil)) dep3 := make(chan *SpecialString) dep4 := make(chan *SpecialString) typRecv := reflect.ChanOf(reflect.RecvDir, reflect.TypeOf(dep3).Elem()) typSend := reflect.ChanOf(reflect.SendDir, reflect.TypeOf(dep4).Elem()) injector.Set(typRecv, reflect.ValueOf(dep3)) injector.Set(typSend, reflect.ValueOf(dep4)) _, err := injector.Invoke(func(d1 string, d2 SpecialString, d3 <-chan *SpecialString, d4 chan<- *SpecialString) { expect(t, d1, dep) expect(t, d2, dep2) expect(t, reflect.TypeOf(d3).Elem(), reflect.TypeOf(dep3).Elem()) expect(t, reflect.TypeOf(d4).Elem(), reflect.TypeOf(dep4).Elem()) expect(t, reflect.TypeOf(d3).ChanDir(), reflect.RecvDir) expect(t, reflect.TypeOf(d4).ChanDir(), reflect.SendDir) }) expect(t, err, nil) }
func TestInjectImplementors(t *testing.T) { injector := inject.New() g := &Greeter{"Jeremy"} injector.Map(g) expect(t, injector.GetVal(inject.InterfaceOf((*fmt.Stringer)(nil))).IsValid(), true) }
func Test_InjectorGet(t *testing.T) { injector := inject.New() injector.Map("some dependency") expect(t, injector.GetVal(reflect.TypeOf("string")).IsValid(), true) expect(t, injector.GetVal(reflect.TypeOf(11)).IsValid(), false) }
func Test_InjectorApply(t *testing.T) { injector := inject.New() injector.Map("a dep").MapTo("another dep", (*SpecialString)(nil)) s := TestStruct{} err := injector.Apply(&s) expect(t, err, nil) expect(t, s.Dep1, "a dep") expect(t, s.Dep2, "another dep") }
// NewWithLogger creates a bare bones Macaron instance. // Use this method if you want to have full control over the middleware that is used. // You can specify logger output writer with this function. func NewWithLogger(out io.Writer) *Macaron { m := &Macaron{ Injector: inject.New(), action: func() {}, Router: NewRouter(), logger: log.New(out, "[Macaron] ", 0), } m.Router.m = m m.Map(m.logger) m.Map(defaultReturnHandler()) m.NotFound(http.NotFound) m.InternalServerError(func(rw http.ResponseWriter, err error) { http.Error(rw, err.Error(), 500) }) return m }
func (m *Macaron) createContext(rw http.ResponseWriter, req *http.Request) *Context { c := &Context{ Injector: inject.New(), handlers: m.handlers, action: m.action, index: 0, Router: m.Router, Req: Request{req}, Resp: NewResponseWriter(rw), Data: make(map[string]interface{}), } c.SetParent(m) c.Map(c) c.MapTo(c.Resp, (*http.ResponseWriter)(nil)) c.Map(req) return c }
// NewWithLogger creates a bare bones Macaron instance. // Use this method if you want to have full control over the middleware that is used. // You can specify logger output writer with this function. func NewWithLogger(out io.Writer) *Macaron { m := &Macaron{ Injector: inject.New(), action: func() {}, Router: NewRouter(), logger: log.New(out, "[Macaron] ", 0), } m.Router.m = m m.Map(m.logger) m.Map(defaultReturnHandler()) m.notFound = func(resp http.ResponseWriter, req *http.Request) { c := m.createContext(resp, req) c.handlers = append(c.handlers, http.NotFound) c.run() } return m }
func Test_InjectorInvokeReturnValues(t *testing.T) { injector := inject.New() expect(t, injector == nil, false) dep := "some dependency" injector.Map(dep) dep2 := "another dep" injector.MapTo(dep2, (*SpecialString)(nil)) result, err := injector.Invoke(func(d1 string, d2 SpecialString) string { expect(t, d1, dep) expect(t, d2, dep2) return "Hello world" }) expect(t, result[0].String(), "Hello world") expect(t, err, nil) }
func Test_InjectorSet(t *testing.T) { injector := inject.New() typ := reflect.TypeOf("string") typSend := reflect.ChanOf(reflect.SendDir, typ) typRecv := reflect.ChanOf(reflect.RecvDir, typ) // instantiating unidirectional channels is not possible using reflect // http://golang.org/src/pkg/reflect/value.go?s=60463:60504#L2064 chanRecv := reflect.MakeChan(reflect.ChanOf(reflect.BothDir, typ), 0) chanSend := reflect.MakeChan(reflect.ChanOf(reflect.BothDir, typ), 0) injector.Set(typSend, chanSend) injector.Set(typRecv, chanRecv) expect(t, injector.GetVal(typSend).IsValid(), true) expect(t, injector.GetVal(typRecv).IsValid(), true) expect(t, injector.GetVal(chanSend.Type()).IsValid(), false) }