wire: report an error if a func with wire.Build in it is an invalid injector (google/go-cloud#487)

This commit is contained in:
Robert van Gent
2018-09-27 15:30:13 -07:00
committed by Ross Light
parent 3bc7933406
commit ec7cb36215
6 changed files with 124 additions and 34 deletions

View File

@@ -0,0 +1,36 @@
// Copyright 2018 The Go Cloud Authors
//
// 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
//
// https://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 main
import (
"fmt"
)
func main() {
foo := injectFoo()
bar := injectBar()
fmt.Println(foo)
fmt.Println(bar)
}
type Foo int
type Bar int
func provideFoo() Foo {
return Foo(42)
}
func provideBar() Bar {
return Bar(99)
}

View File

@@ -0,0 +1,33 @@
// Copyright 2018 The Go Cloud Authors
//
// 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
//
// https://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.
//+build wireinject
package main
import (
"github.com/google/go-cloud/wire"
)
func injectFoo() Foo {
// This non-call statement makes this an invalid injector.
_ = 42
panic(wire.Build(provideFoo))
}
func injectBar() Bar {
// Two call statements are also invalid.
panic(wire.Build(provideBar))
panic(wire.Build(provideBar))
}

View File

@@ -0,0 +1 @@
example.com/foo

View File

@@ -0,0 +1,4 @@
a call to wire.Build indicates that this function is an injector, but injectors
must consist of only the wire.Build call and an optional return
a call to wire.Build indicates that this function is an injector, but injectors
must consist of only the wire.Build call and an optional return