authlogger_test.go 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. package authlogger
  2. import (
  3. "net/http"
  4. "net/url"
  5. "os"
  6. "testing"
  7. "time"
  8. )
  9. var filePath = "./system/auth/"
  10. func setupSuite(t *testing.T) func(t *testing.T) {
  11. t.Log("Setting up env")
  12. os.Mkdir(filePath, 0777)
  13. // Return a function to teardown the test
  14. return func(t *testing.T) {
  15. t.Log("Cleaning up")
  16. err := os.RemoveAll(filePath)
  17. if err != nil {
  18. t.Fatalf("Failed to clean up: %v", err)
  19. }
  20. }
  21. }
  22. func TestNewLogger(t *testing.T) {
  23. teardownSuite := setupSuite(t)
  24. defer teardownSuite(t)
  25. // Test creating a new logger
  26. logger, err := NewLogger()
  27. if err != nil {
  28. t.Fatalf("Failed to create a new logger: %v", err)
  29. }
  30. defer logger.Close()
  31. // Ensure that the logger's database is not nil
  32. if logger.database == nil {
  33. t.Error("Logger's database should not be nil")
  34. }
  35. }
  36. func TestLogAuth(t *testing.T) {
  37. teardownSuite := setupSuite(t)
  38. defer teardownSuite(t)
  39. // Setup a test HTTP request
  40. request, err := http.NewRequest("POST", "/login", nil)
  41. if err != nil {
  42. t.Fatal(err)
  43. }
  44. form := url.Values{}
  45. form.Add("username", "automatictest")
  46. request.RemoteAddr = "8.8.8.8:8080"
  47. request.PostForm = form
  48. // Setup a test server to capture the response
  49. //rr := httptest.NewRecorder()
  50. // Create a new logger
  51. logger, err := NewLogger()
  52. if err != nil {
  53. t.Fatalf("Failed to create a new logger: %v", err)
  54. }
  55. defer logger.Close()
  56. // Test logging authentication with a successful login
  57. err = logger.LogAuth(request, true)
  58. if err != nil {
  59. t.Fatalf("Failed to log authentication: %v", err)
  60. }
  61. if len(logger.ListSummary()) != 1 {
  62. t.Fatalf("Expected list summary:1, curr: 0")
  63. }
  64. summary, err := logger.ListRecords(logger.ListSummary()[0])
  65. if err != nil {
  66. t.Fatalf("Failed to list records: %v", err)
  67. }
  68. // should be only 1
  69. for _, record := range summary {
  70. if record.AuthType != "web" {
  71. t.Fatalf("AuthType expected: %v, got: %v", "web", record.AuthType)
  72. }
  73. if record.IpAddr != "8.8.8.8" {
  74. t.Fatalf("IpAddr expected: %v, got: %v", "8.8.8.8", record.IpAddr)
  75. }
  76. if record.LoginSucceed != true {
  77. t.Fatalf("LoginSucceed expected: %v, got: %v", true, record.LoginSucceed)
  78. }
  79. if record.Port != 8080 {
  80. t.Fatalf("Port expected: %v, got: %v", 8080, record.LoginSucceed)
  81. }
  82. if record.TargetUsername != "automatictest" {
  83. t.Fatalf("TargetUsername expected: %v, got: %v", "automatictest", record.TargetUsername)
  84. }
  85. }
  86. }
  87. func TestListSummary(t *testing.T) {
  88. teardownSuite := setupSuite(t)
  89. defer teardownSuite(t)
  90. // Create a new logger
  91. logger, err := NewLogger()
  92. if err != nil {
  93. t.Fatalf("Failed to create a new logger: %v", err)
  94. }
  95. defer logger.Close()
  96. // Test listing summary
  97. summary := logger.ListSummary()
  98. // Assuming there is at least one table in the test environment
  99. if len(summary) != 0 {
  100. t.Fatal("Expected at least one table in the summary, got none")
  101. }
  102. }
  103. func TestListRecords(t *testing.T) {
  104. teardownSuite := setupSuite(t)
  105. defer teardownSuite(t)
  106. // Create a new logger
  107. logger, err := NewLogger()
  108. if err != nil {
  109. t.Fatalf("Failed to create a new logger: %v", err)
  110. }
  111. defer logger.Close()
  112. err = logger.LogAuthByRequestInfo("testUser", "192.168.1.1:8080", time.Now().Unix(), true, "custom")
  113. // Assuming there is at least one table in the test environment
  114. summary := logger.ListSummary()
  115. if len(summary) == 0 {
  116. t.Fatalf("Expected at least one record in the table, got none")
  117. }
  118. // Test listing records from the first table
  119. records, err := logger.ListRecords(summary[0])
  120. if err != nil {
  121. t.Fatalf("Failed to list records: %v", err)
  122. }
  123. // Assuming there are records in the table
  124. if len(records) == 0 {
  125. t.Fatalf("Expected at least one record in the table, got none")
  126. }
  127. }
  128. func TestLogAuthByRequestInfo(t *testing.T) {
  129. teardownSuite := setupSuite(t)
  130. defer teardownSuite(t)
  131. // Create a new logger
  132. logger, err := NewLogger()
  133. if err != nil {
  134. t.Fatalf("Failed to create a new logger: %v", err)
  135. }
  136. defer logger.Close()
  137. // Test logging authentication with custom request info
  138. tt := time.Now().Unix()
  139. err = logger.LogAuthByRequestInfo("testUser", "192.168.1.1:8080", tt, true, "custom")
  140. if err != nil {
  141. t.Errorf("Failed to log authentication with custom request info: %v", err)
  142. }
  143. if len(logger.ListSummary()) != 1 {
  144. t.Fatalf("Expected list summary:1, curr: 0")
  145. }
  146. summary, err := logger.ListRecords(logger.ListSummary()[0])
  147. if err != nil {
  148. t.Fatalf("Failed to list records: %v", err)
  149. }
  150. // should be only 1
  151. for _, record := range summary {
  152. if record.AuthType != "custom" {
  153. t.Fatalf("AuthType expected: %v, got: %v", "custom", record.AuthType)
  154. }
  155. if record.IpAddr != "192.168.1.1" {
  156. t.Fatalf("IpAddr expected: %v, got: %v", "192.168.1.1", record.IpAddr)
  157. }
  158. if record.LoginSucceed != true {
  159. t.Fatalf("LoginSucceed expected: %v, got: %v", true, record.LoginSucceed)
  160. }
  161. if record.Port != 8080 {
  162. t.Fatalf("Port expected: %v, got: %v", 8080, record.LoginSucceed)
  163. }
  164. if record.TargetUsername != "testUser" {
  165. t.Fatalf("TargetUsername expected: %v, got: %v", "testUser", record.TargetUsername)
  166. }
  167. if record.Timestamp != tt {
  168. t.Fatalf("Timestamp expected: %v, got: %v", tt, record.Timestamp)
  169. }
  170. }
  171. }