manual.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /*
  2. *
  3. * Copyright 2017 gRPC authors.
  4. *
  5. * Licensed under the Apache License, Version 2.0 (the "License");
  6. * you may not use this file except in compliance with the License.
  7. * You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. *
  17. */
  18. // Package manual defines a resolver that can be used to manually send resolved
  19. // addresses to ClientConn.
  20. package manual
  21. import (
  22. "sync"
  23. "google.golang.org/grpc/resolver"
  24. )
  25. // NewBuilderWithScheme creates a new test resolver builder with the given scheme.
  26. func NewBuilderWithScheme(scheme string) *Resolver {
  27. return &Resolver{
  28. BuildCallback: func(resolver.Target, resolver.ClientConn, resolver.BuildOptions) {},
  29. ResolveNowCallback: func(resolver.ResolveNowOptions) {},
  30. CloseCallback: func() {},
  31. scheme: scheme,
  32. }
  33. }
  34. // Resolver is also a resolver builder.
  35. // It's build() function always returns itself.
  36. type Resolver struct {
  37. // BuildCallback is called when the Build method is called. Must not be
  38. // nil. Must not be changed after the resolver may be built.
  39. BuildCallback func(resolver.Target, resolver.ClientConn, resolver.BuildOptions)
  40. // ResolveNowCallback is called when the ResolveNow method is called on the
  41. // resolver. Must not be nil. Must not be changed after the resolver may
  42. // be built.
  43. ResolveNowCallback func(resolver.ResolveNowOptions)
  44. // CloseCallback is called when the Close method is called. Must not be
  45. // nil. Must not be changed after the resolver may be built.
  46. CloseCallback func()
  47. scheme string
  48. // Fields actually belong to the resolver.
  49. mu sync.Mutex // Guards access to CC.
  50. CC resolver.ClientConn
  51. bootstrapState *resolver.State
  52. }
  53. // InitialState adds initial state to the resolver so that UpdateState doesn't
  54. // need to be explicitly called after Dial.
  55. func (r *Resolver) InitialState(s resolver.State) {
  56. r.bootstrapState = &s
  57. }
  58. // Build returns itself for Resolver, because it's both a builder and a resolver.
  59. func (r *Resolver) Build(target resolver.Target, cc resolver.ClientConn, opts resolver.BuildOptions) (resolver.Resolver, error) {
  60. r.mu.Lock()
  61. r.CC = cc
  62. r.mu.Unlock()
  63. r.BuildCallback(target, cc, opts)
  64. if r.bootstrapState != nil {
  65. r.UpdateState(*r.bootstrapState)
  66. }
  67. return r, nil
  68. }
  69. // Scheme returns the test scheme.
  70. func (r *Resolver) Scheme() string {
  71. return r.scheme
  72. }
  73. // ResolveNow is a noop for Resolver.
  74. func (r *Resolver) ResolveNow(o resolver.ResolveNowOptions) {
  75. r.ResolveNowCallback(o)
  76. }
  77. // Close is a noop for Resolver.
  78. func (r *Resolver) Close() {
  79. r.CloseCallback()
  80. }
  81. // UpdateState calls CC.UpdateState.
  82. func (r *Resolver) UpdateState(s resolver.State) {
  83. r.mu.Lock()
  84. r.CC.UpdateState(s)
  85. r.mu.Unlock()
  86. }
  87. // ReportError calls CC.ReportError.
  88. func (r *Resolver) ReportError(err error) {
  89. r.mu.Lock()
  90. r.CC.ReportError(err)
  91. r.mu.Unlock()
  92. }