ldap_test.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. package ldap
  2. import (
  3. "errors"
  4. "testing"
  5. . "github.com/smartystreets/goconvey/convey"
  6. "gopkg.in/ldap.v3"
  7. "github.com/grafana/grafana/pkg/infra/log"
  8. )
  9. func TestPublicAPI(t *testing.T) {
  10. Convey("New()", t, func() {
  11. Convey("Should return ", func() {
  12. result := New(&ServerConfig{
  13. Attr: AttributeMap{},
  14. SearchBaseDNs: []string{"BaseDNHere"},
  15. })
  16. So(result, ShouldImplement, (*IServer)(nil))
  17. })
  18. })
  19. Convey("Users()", t, func() {
  20. Convey("Finds one user", func() {
  21. MockConnection := &MockConnection{}
  22. entry := ldap.Entry{
  23. DN: "dn", Attributes: []*ldap.EntryAttribute{
  24. {Name: "username", Values: []string{"roelgerrits"}},
  25. {Name: "surname", Values: []string{"Gerrits"}},
  26. {Name: "email", Values: []string{"roel@test.com"}},
  27. {Name: "name", Values: []string{"Roel"}},
  28. {Name: "memberof", Values: []string{"admins"}},
  29. }}
  30. result := ldap.SearchResult{Entries: []*ldap.Entry{&entry}}
  31. MockConnection.setSearchResult(&result)
  32. // Set up attribute map without surname and email
  33. server := &Server{
  34. Config: &ServerConfig{
  35. Attr: AttributeMap{
  36. Username: "username",
  37. Name: "name",
  38. MemberOf: "memberof",
  39. },
  40. SearchBaseDNs: []string{"BaseDNHere"},
  41. },
  42. Connection: MockConnection,
  43. log: log.New("test-logger"),
  44. }
  45. searchResult, err := server.Users([]string{"roelgerrits"})
  46. So(err, ShouldBeNil)
  47. So(searchResult, ShouldNotBeNil)
  48. // User should be searched in ldap
  49. So(MockConnection.SearchCalled, ShouldBeTrue)
  50. // No empty attributes should be added to the search request
  51. So(len(MockConnection.SearchAttributes), ShouldEqual, 3)
  52. })
  53. Convey("Handles a error", func() {
  54. expected := errors.New("Killa-gorilla")
  55. MockConnection := &MockConnection{}
  56. MockConnection.setSearchError(expected)
  57. // Set up attribute map without surname and email
  58. server := &Server{
  59. Config: &ServerConfig{
  60. SearchBaseDNs: []string{"BaseDNHere"},
  61. },
  62. Connection: MockConnection,
  63. log: log.New("test-logger"),
  64. }
  65. _, err := server.Users([]string{"roelgerrits"})
  66. So(err, ShouldEqual, expected)
  67. })
  68. Convey("Should return empty slice if none were found", func() {
  69. MockConnection := &MockConnection{}
  70. result := ldap.SearchResult{Entries: []*ldap.Entry{}}
  71. MockConnection.setSearchResult(&result)
  72. // Set up attribute map without surname and email
  73. server := &Server{
  74. Config: &ServerConfig{
  75. SearchBaseDNs: []string{"BaseDNHere"},
  76. },
  77. Connection: MockConnection,
  78. log: log.New("test-logger"),
  79. }
  80. searchResult, err := server.Users([]string{"roelgerrits"})
  81. So(err, ShouldBeNil)
  82. So(searchResult, ShouldBeEmpty)
  83. })
  84. })
  85. Convey("Auth()", t, func() {
  86. Convey("Should use provided DN and password", func() {
  87. connection := &MockConnection{}
  88. var actualUsername, actualPassword string
  89. connection.BindProvider = func(username, password string) error {
  90. actualUsername = username
  91. actualPassword = password
  92. return nil
  93. }
  94. server := &Server{
  95. Connection: connection,
  96. Config: &ServerConfig{
  97. BindDN: "cn=admin,dc=grafana,dc=org",
  98. },
  99. }
  100. dn := "cn=user,ou=users,dc=grafana,dc=org"
  101. err := server.Auth(dn, "pwd")
  102. So(err, ShouldBeNil)
  103. So(actualUsername, ShouldEqual, dn)
  104. So(actualPassword, ShouldEqual, "pwd")
  105. })
  106. Convey("Should handle an error", func() {
  107. connection := &MockConnection{}
  108. expected := &ldap.Error{
  109. ResultCode: uint16(25),
  110. }
  111. connection.BindProvider = func(username, password string) error {
  112. return expected
  113. }
  114. server := &Server{
  115. Connection: connection,
  116. Config: &ServerConfig{
  117. BindDN: "cn=%s,ou=users,dc=grafana,dc=org",
  118. },
  119. log: log.New("test-logger"),
  120. }
  121. err := server.Auth("user", "pwd")
  122. So(err, ShouldEqual, expected)
  123. })
  124. })
  125. Convey("AuthAdmin()", t, func() {
  126. Convey("Should use admin DN and password", func() {
  127. connection := &MockConnection{}
  128. var actualUsername, actualPassword string
  129. connection.BindProvider = func(username, password string) error {
  130. actualUsername = username
  131. actualPassword = password
  132. return nil
  133. }
  134. dn := "cn=admin,dc=grafana,dc=org"
  135. server := &Server{
  136. Connection: connection,
  137. Config: &ServerConfig{
  138. BindPassword: "pwd",
  139. BindDN: dn,
  140. },
  141. }
  142. err := server.AuthAdmin()
  143. So(err, ShouldBeNil)
  144. So(actualUsername, ShouldEqual, dn)
  145. So(actualPassword, ShouldEqual, "pwd")
  146. })
  147. Convey("Should handle an error", func() {
  148. connection := &MockConnection{}
  149. expected := &ldap.Error{
  150. ResultCode: uint16(25),
  151. }
  152. connection.BindProvider = func(username, password string) error {
  153. return expected
  154. }
  155. dn := "cn=admin,dc=grafana,dc=org"
  156. server := &Server{
  157. Connection: connection,
  158. Config: &ServerConfig{
  159. BindPassword: "pwd",
  160. BindDN: dn,
  161. },
  162. log: log.New("test-logger"),
  163. }
  164. err := server.AuthAdmin()
  165. So(err, ShouldEqual, expected)
  166. })
  167. })
  168. }