ldap_test.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  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 ignore passsed username 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. BindPassword: "bindpwd",
  99. },
  100. }
  101. err := server.Auth("user", "pwd")
  102. So(err, ShouldBeNil)
  103. So(actualUsername, ShouldEqual, "cn=admin,dc=grafana,dc=org")
  104. So(actualPassword, ShouldEqual, "bindpwd")
  105. })
  106. Convey("Given bind dn configured", func() {
  107. connection := &MockConnection{}
  108. var actualUsername, actualPassword string
  109. connection.bindProvider = func(username, password string) error {
  110. actualUsername = username
  111. actualPassword = password
  112. return nil
  113. }
  114. server := &Server{
  115. Connection: connection,
  116. Config: &ServerConfig{
  117. BindDN: "cn=%s,o=users,dc=grafana,dc=org",
  118. },
  119. }
  120. err := server.Auth("user", "pwd")
  121. So(err, ShouldBeNil)
  122. So(actualUsername, ShouldEqual, "cn=user,o=users,dc=grafana,dc=org")
  123. So(actualPassword, ShouldEqual, "pwd")
  124. })
  125. Convey("Should handle an error", func() {
  126. connection := &MockConnection{}
  127. expected := &ldap.Error{
  128. ResultCode: uint16(25),
  129. }
  130. connection.bindProvider = func(username, password string) error {
  131. return expected
  132. }
  133. server := &Server{
  134. Connection: connection,
  135. Config: &ServerConfig{
  136. BindDN: "cn=%s,o=users,dc=grafana,dc=org",
  137. },
  138. log: log.New("test-logger"),
  139. }
  140. err := server.Auth("user", "pwd")
  141. So(err, ShouldEqual, expected)
  142. })
  143. })
  144. }