test.go 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  1. package ldap
  2. import (
  3. "context"
  4. "crypto/tls"
  5. . "github.com/smartystreets/goconvey/convey"
  6. "gopkg.in/ldap.v3"
  7. "github.com/grafana/grafana/pkg/bus"
  8. "github.com/grafana/grafana/pkg/models"
  9. "github.com/grafana/grafana/pkg/services/login"
  10. )
  11. // MockConnection struct for testing
  12. type MockConnection struct {
  13. SearchResult *ldap.SearchResult
  14. SearchCalled bool
  15. SearchAttributes []string
  16. AddParams *ldap.AddRequest
  17. AddCalled bool
  18. DelParams *ldap.DelRequest
  19. DelCalled bool
  20. bindProvider func(username, password string) error
  21. unauthenticatedBindProvider func(username string) error
  22. }
  23. // Bind mocks Bind connection function
  24. func (c *MockConnection) Bind(username, password string) error {
  25. if c.bindProvider != nil {
  26. return c.bindProvider(username, password)
  27. }
  28. return nil
  29. }
  30. // UnauthenticatedBind mocks UnauthenticatedBind connection function
  31. func (c *MockConnection) UnauthenticatedBind(username string) error {
  32. if c.unauthenticatedBindProvider != nil {
  33. return c.unauthenticatedBindProvider(username)
  34. }
  35. return nil
  36. }
  37. // Close mocks Close connection function
  38. func (c *MockConnection) Close() {}
  39. func (c *MockConnection) setSearchResult(result *ldap.SearchResult) {
  40. c.SearchResult = result
  41. }
  42. // Search mocks Search connection function
  43. func (c *MockConnection) Search(sr *ldap.SearchRequest) (*ldap.SearchResult, error) {
  44. c.SearchCalled = true
  45. c.SearchAttributes = sr.Attributes
  46. return c.SearchResult, nil
  47. }
  48. // Add mocks Add connection function
  49. func (c *MockConnection) Add(request *ldap.AddRequest) error {
  50. c.AddCalled = true
  51. c.AddParams = request
  52. return nil
  53. }
  54. // Del mocks Del connection function
  55. func (c *MockConnection) Del(request *ldap.DelRequest) error {
  56. c.DelCalled = true
  57. c.DelParams = request
  58. return nil
  59. }
  60. // StartTLS mocks StartTLS connection function
  61. func (c *MockConnection) StartTLS(*tls.Config) error {
  62. return nil
  63. }
  64. func serverScenario(desc string, fn scenarioFunc) {
  65. Convey(desc, func() {
  66. defer bus.ClearBusHandlers()
  67. sc := &scenarioContext{
  68. loginUserQuery: &models.LoginUserQuery{
  69. Username: "user",
  70. Password: "pwd",
  71. IpAddress: "192.168.1.1:56433",
  72. },
  73. }
  74. loginService := &login.LoginService{
  75. Bus: bus.GetBus(),
  76. }
  77. bus.AddHandler("test", loginService.UpsertUser)
  78. bus.AddHandlerCtx("test", func(ctx context.Context, cmd *models.SyncTeamsCommand) error {
  79. return nil
  80. })
  81. bus.AddHandlerCtx("test", func(ctx context.Context, cmd *models.UpdateUserPermissionsCommand) error {
  82. sc.updateUserPermissionsCmd = cmd
  83. return nil
  84. })
  85. bus.AddHandler("test", func(cmd *models.GetUserByAuthInfoQuery) error {
  86. sc.getUserByAuthInfoQuery = cmd
  87. sc.getUserByAuthInfoQuery.Result = &models.User{Login: cmd.Login}
  88. return nil
  89. })
  90. bus.AddHandler("test", func(cmd *models.GetUserOrgListQuery) error {
  91. sc.getUserOrgListQuery = cmd
  92. return nil
  93. })
  94. bus.AddHandler("test", func(cmd *models.CreateUserCommand) error {
  95. sc.createUserCmd = cmd
  96. sc.createUserCmd.Result = models.User{Login: cmd.Login}
  97. return nil
  98. })
  99. bus.AddHandler("test", func(cmd *models.GetExternalUserInfoByLoginQuery) error {
  100. sc.getExternalUserInfoByLoginQuery = cmd
  101. sc.getExternalUserInfoByLoginQuery.Result = &models.ExternalUserInfo{UserId: 42, IsDisabled: false}
  102. return nil
  103. })
  104. bus.AddHandler("test", func(cmd *models.DisableUserCommand) error {
  105. sc.disableExternalUserCalled = true
  106. sc.disableUserCmd = cmd
  107. return nil
  108. })
  109. bus.AddHandler("test", func(cmd *models.AddOrgUserCommand) error {
  110. sc.addOrgUserCmd = cmd
  111. return nil
  112. })
  113. bus.AddHandler("test", func(cmd *models.UpdateOrgUserCommand) error {
  114. sc.updateOrgUserCmd = cmd
  115. return nil
  116. })
  117. bus.AddHandler("test", func(cmd *models.RemoveOrgUserCommand) error {
  118. sc.removeOrgUserCmd = cmd
  119. return nil
  120. })
  121. bus.AddHandler("test", func(cmd *models.UpdateUserCommand) error {
  122. sc.updateUserCmd = cmd
  123. return nil
  124. })
  125. bus.AddHandler("test", func(cmd *models.SetUsingOrgCommand) error {
  126. sc.setUsingOrgCmd = cmd
  127. return nil
  128. })
  129. fn(sc)
  130. })
  131. }
  132. type scenarioContext struct {
  133. loginUserQuery *models.LoginUserQuery
  134. getUserByAuthInfoQuery *models.GetUserByAuthInfoQuery
  135. getExternalUserInfoByLoginQuery *models.GetExternalUserInfoByLoginQuery
  136. getUserOrgListQuery *models.GetUserOrgListQuery
  137. createUserCmd *models.CreateUserCommand
  138. disableUserCmd *models.DisableUserCommand
  139. addOrgUserCmd *models.AddOrgUserCommand
  140. updateOrgUserCmd *models.UpdateOrgUserCommand
  141. removeOrgUserCmd *models.RemoveOrgUserCommand
  142. updateUserCmd *models.UpdateUserCommand
  143. setUsingOrgCmd *models.SetUsingOrgCommand
  144. updateUserPermissionsCmd *models.UpdateUserPermissionsCommand
  145. disableExternalUserCalled bool
  146. }
  147. func (sc *scenarioContext) userQueryReturns(user *models.User) {
  148. bus.AddHandler("test", func(query *models.GetUserByAuthInfoQuery) error {
  149. if user == nil {
  150. return models.ErrUserNotFound
  151. }
  152. query.Result = user
  153. return nil
  154. })
  155. bus.AddHandler("test", func(query *models.SetAuthInfoCommand) error {
  156. return nil
  157. })
  158. }
  159. func (sc *scenarioContext) userOrgsQueryReturns(orgs []*models.UserOrgDTO) {
  160. bus.AddHandler("test", func(query *models.GetUserOrgListQuery) error {
  161. query.Result = orgs
  162. return nil
  163. })
  164. }
  165. func (sc *scenarioContext) getExternalUserInfoByLoginQueryReturns(externalUser *models.ExternalUserInfo) {
  166. bus.AddHandler("test", func(cmd *models.GetExternalUserInfoByLoginQuery) error {
  167. sc.getExternalUserInfoByLoginQuery = cmd
  168. sc.getExternalUserInfoByLoginQuery.Result = &models.ExternalUserInfo{
  169. UserId: externalUser.UserId,
  170. IsDisabled: externalUser.IsDisabled,
  171. }
  172. return nil
  173. })
  174. }
  175. type scenarioFunc func(c *scenarioContext)