test.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  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. type mockConnection struct {
  12. searchResult *ldap.SearchResult
  13. searchCalled bool
  14. searchAttributes []string
  15. addParams *ldap.AddRequest
  16. addCalled bool
  17. delParams *ldap.DelRequest
  18. delCalled bool
  19. bindProvider func(username, password string) error
  20. unauthenticatedBindProvider func(username string) error
  21. }
  22. func (c *mockConnection) Bind(username, password string) error {
  23. if c.bindProvider != nil {
  24. return c.bindProvider(username, password)
  25. }
  26. return nil
  27. }
  28. func (c *mockConnection) UnauthenticatedBind(username string) error {
  29. if c.unauthenticatedBindProvider != nil {
  30. return c.unauthenticatedBindProvider(username)
  31. }
  32. return nil
  33. }
  34. func (c *mockConnection) Close() {}
  35. func (c *mockConnection) setSearchResult(result *ldap.SearchResult) {
  36. c.searchResult = result
  37. }
  38. func (c *mockConnection) Search(sr *ldap.SearchRequest) (*ldap.SearchResult, error) {
  39. c.searchCalled = true
  40. c.searchAttributes = sr.Attributes
  41. return c.searchResult, nil
  42. }
  43. func (c *mockConnection) Add(request *ldap.AddRequest) error {
  44. c.addCalled = true
  45. c.addParams = request
  46. return nil
  47. }
  48. func (c *mockConnection) Del(request *ldap.DelRequest) error {
  49. c.delCalled = true
  50. c.delParams = request
  51. return nil
  52. }
  53. func (c *mockConnection) StartTLS(*tls.Config) error {
  54. return nil
  55. }
  56. func authScenario(desc string, fn scenarioFunc) {
  57. Convey(desc, func() {
  58. defer bus.ClearBusHandlers()
  59. sc := &scenarioContext{
  60. loginUserQuery: &models.LoginUserQuery{
  61. Username: "user",
  62. Password: "pwd",
  63. IpAddress: "192.168.1.1:56433",
  64. },
  65. }
  66. loginService := &login.LoginService{
  67. Bus: bus.GetBus(),
  68. }
  69. bus.AddHandler("test", loginService.UpsertUser)
  70. bus.AddHandlerCtx("test", func(ctx context.Context, cmd *models.SyncTeamsCommand) error {
  71. return nil
  72. })
  73. bus.AddHandlerCtx("test", func(ctx context.Context, cmd *models.UpdateUserPermissionsCommand) error {
  74. sc.updateUserPermissionsCmd = cmd
  75. return nil
  76. })
  77. bus.AddHandler("test", func(cmd *models.GetUserByAuthInfoQuery) error {
  78. sc.getUserByAuthInfoQuery = cmd
  79. sc.getUserByAuthInfoQuery.Result = &models.User{Login: cmd.Login}
  80. return nil
  81. })
  82. bus.AddHandler("test", func(cmd *models.GetUserOrgListQuery) error {
  83. sc.getUserOrgListQuery = cmd
  84. return nil
  85. })
  86. bus.AddHandler("test", func(cmd *models.CreateUserCommand) error {
  87. sc.createUserCmd = cmd
  88. sc.createUserCmd.Result = models.User{Login: cmd.Login}
  89. return nil
  90. })
  91. bus.AddHandler("test", func(cmd *models.AddOrgUserCommand) error {
  92. sc.addOrgUserCmd = cmd
  93. return nil
  94. })
  95. bus.AddHandler("test", func(cmd *models.UpdateOrgUserCommand) error {
  96. sc.updateOrgUserCmd = cmd
  97. return nil
  98. })
  99. bus.AddHandler("test", func(cmd *models.RemoveOrgUserCommand) error {
  100. sc.removeOrgUserCmd = cmd
  101. return nil
  102. })
  103. bus.AddHandler("test", func(cmd *models.UpdateUserCommand) error {
  104. sc.updateUserCmd = cmd
  105. return nil
  106. })
  107. bus.AddHandler("test", func(cmd *models.SetUsingOrgCommand) error {
  108. sc.setUsingOrgCmd = cmd
  109. return nil
  110. })
  111. fn(sc)
  112. })
  113. }
  114. type scenarioContext struct {
  115. loginUserQuery *models.LoginUserQuery
  116. getUserByAuthInfoQuery *models.GetUserByAuthInfoQuery
  117. getUserOrgListQuery *models.GetUserOrgListQuery
  118. createUserCmd *models.CreateUserCommand
  119. addOrgUserCmd *models.AddOrgUserCommand
  120. updateOrgUserCmd *models.UpdateOrgUserCommand
  121. removeOrgUserCmd *models.RemoveOrgUserCommand
  122. updateUserCmd *models.UpdateUserCommand
  123. setUsingOrgCmd *models.SetUsingOrgCommand
  124. updateUserPermissionsCmd *models.UpdateUserPermissionsCommand
  125. }
  126. func (sc *scenarioContext) userQueryReturns(user *models.User) {
  127. bus.AddHandler("test", func(query *models.GetUserByAuthInfoQuery) error {
  128. if user == nil {
  129. return models.ErrUserNotFound
  130. }
  131. query.Result = user
  132. return nil
  133. })
  134. bus.AddHandler("test", func(query *models.SetAuthInfoCommand) error {
  135. return nil
  136. })
  137. }
  138. func (sc *scenarioContext) userOrgsQueryReturns(orgs []*models.UserOrgDTO) {
  139. bus.AddHandler("test", func(query *models.GetUserOrgListQuery) error {
  140. query.Result = orgs
  141. return nil
  142. })
  143. }
  144. type scenarioFunc func(c *scenarioContext)