Skip to content

Commit

Permalink
Rework mock service and tests to accommadate mockgen
Browse files Browse the repository at this point in the history
  • Loading branch information
Chuntao Lu committed Feb 17, 2018
1 parent a584923 commit ae8a5b1
Show file tree
Hide file tree
Showing 7 changed files with 67 additions and 36 deletions.
27 changes: 19 additions & 8 deletions codegen/template_bundle/template_files.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

14 changes: 10 additions & 4 deletions codegen/templates/module_mock_initializer.tmpl
Original file line number Diff line number Diff line change
Expand Up @@ -5,16 +5,21 @@
package module

import (
"testing"

"github.com/golang/mock/gomock"
zanzibar "github.com/uber/zanzibar/runtime"

{{range $classType, $moduleInstances := $instance.RecursiveDependencies -}}
{{range $idx, $moduleInstance := $moduleInstances -}}
{{if eq $classType $leafClass -}}
{{$moduleInstance.PackageInfo.ImportPackageAlias}} "{{$moduleInstance.PackageInfo.ImportPackagePath}}/mock_client"
{{else -}}
{{$moduleInstance.PackageInfo.ImportPackageAlias}} "{{$moduleInstance.PackageInfo.ImportPackagePath}}"
{{if not (eq $classType $leafClass) -}}
{{$moduleInstance.PackageInfo.ModulePackageAlias}} "{{$moduleInstance.PackageInfo.ModulePackagePath}}"
{{end -}}
{{end -}}
{{end}}

zanzibar "github.com/uber/zanzibar/runtime"
)

{{$moduleInstances := (index $instance.RecursiveDependencies $leafClass) -}}
Expand All @@ -29,6 +34,7 @@ type {{$mockDeps}} struct {
// for the {{$instance.InstanceName}} {{$instance.ClassName}} with leaf nodes being mocks
func InitializeDependenciesMock(
g *zanzibar.Gateway,
ctrl *gomock.Controller,
) (*DependenciesTree, *Dependencies, *{{$mockDeps}}) {
tree := &DependenciesTree{}

Expand All @@ -45,7 +51,7 @@ func InitializeDependenciesMock(
{{camel $mockDeps}} := &{{$mockDeps}}{
{{- range $idx, $dependency := $moduleInstances}}
{{- $pkgInfo := $dependency.PackageInfo }}
{{$pkgInfo.QualifiedInstanceName}}: &{{$pkgInfo.ImportPackageAlias}}.Mock{{title $className}}{},
{{$pkgInfo.QualifiedInstanceName}}: {{$pkgInfo.ImportPackageAlias}}.NewMock{{title $className}}(ctrl),
{{- end }}
}
{{- $initializedDeps := printf "initialized%sDependencies" (title $className) }}
Expand Down
10 changes: 8 additions & 2 deletions codegen/templates/service_mock.tmpl
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,11 @@ import (
"net/http"
"path/filepath"
"runtime"
"testing"
"time"


"github.com/golang/mock/gomock"
"github.com/uber/zanzibar/config"
"github.com/uber/zanzibar/runtime"

Expand Down Expand Up @@ -43,13 +45,14 @@ type MockService interface {
type mockService struct {
started bool
server *zanzibar.Gateway
ctrl *gomock.Controller
{{camel $mockType}} *module.{{$mockType}}
httpClient *http.Client
tChannelClient zanzibar.TChannelCaller
}

// MustCreateTestService creates a new MockService, panics if it fails doing so.
func MustCreateTestService() MockService {
func MustCreateTestService(t *testing.T) MockService {
_, file, _, _ := runtime.Caller(0)
currentDir := zanzibar.GetDirnameFromRuntimeCaller(file)
testConfigPath := filepath.Join(currentDir, "../../../config/test.json")
Expand All @@ -60,7 +63,8 @@ func MustCreateTestService() MockService {
panic(err)
}

_, dependencies, mockNodes := module.InitializeDependenciesMock(server)
ctrl := gomock.NewController(t)
_, dependencies, mockNodes := module.InitializeDependenciesMock(server, ctrl)
registerErr := registerDeps(server, dependencies)
if registerErr != nil {
panic(registerErr)
Expand Down Expand Up @@ -91,6 +95,7 @@ func MustCreateTestService() MockService {

return &mockService{
server: server,
ctrl: ctrl,
{{camel $mockType}}: mockNodes,
httpClient: httpClient,
tChannelClient: tchannelClient,
Expand All @@ -107,6 +112,7 @@ func (m *mockService) Start() {

// Stop stops the mock server
func (m *mockService) Stop() {
m.ctrl.Finish()
m.server.Close()
m.started = false
}
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -4,16 +4,16 @@ import (
"bytes"
"testing"

"github.com/golang/mock/gomock"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/mock"

clientContacts "github.com/uber/zanzibar/examples/example-gateway/build/gen-code/clients/contacts/contacts"
endpointContacts "github.com/uber/zanzibar/examples/example-gateway/build/gen-code/endpoints/contacts/contacts"
"github.com/uber/zanzibar/examples/example-gateway/build/services/example-gateway"
)

func TestSaveContactsCall(t *testing.T) {
ms := examplegatewayServiceGenerated.MustCreateTestService()
ms := examplegatewayServiceGenerated.MustCreateTestService(t)
ms.Start()
defer ms.Stop()

Expand All @@ -27,7 +27,7 @@ func TestSaveContactsCall(t *testing.T) {
}
clientResponse := &clientContacts.SaveContactsResponse{}

ms.MockClientNodes().Contacts.On("SaveContacts", mock.Anything, mock.Anything, clientRequest).
ms.MockClientNodes().Contacts.EXPECT().SaveContacts(gomock.Any(), gomock.Any(), clientRequest).
Return(clientResponse, nil, nil)

res, err := ms.MakeHTTPRequest(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,15 @@ import (
"context"
"testing"

"github.com/golang/mock/gomock"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/mock"

"github.com/uber/zanzibar/examples/example-gateway/build/gen-code/endpoints/tchannel/baz/baz"
ms "github.com/uber/zanzibar/examples/example-gateway/build/services/example-gateway"
)

func TestBazCall(t *testing.T) {
ms := ms.MustCreateTestService()
ms := ms.MustCreateTestService(t)
ms.Start()
defer ms.Stop()

Expand All @@ -34,7 +34,7 @@ func TestBazCall(t *testing.T) {

ctx := context.Background()
var result baz.SimpleService_Call_Result
ms.MockClientNodes().Baz.On("Call", mock.Anything, reqHeaders, mock.Anything).
ms.MockClientNodes().Baz.EXPECT().Call(gomock.Any(), reqHeaders, gomock.Any()).
Return(map[string]string{"some-res-header": "something"}, nil)

success, resHeaders, err := ms.MakeTChannelRequest(
Expand Down

0 comments on commit ae8a5b1

Please # to comment.