event_test.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. package gorm_test
  2. import (
  3. "fmt"
  4. "testing"
  5. "time"
  6. "github.com/go-test/deep"
  7. "github.com/porter-dev/porter/api/types"
  8. "github.com/porter-dev/porter/internal/encryption"
  9. "github.com/porter-dev/porter/internal/models"
  10. "gorm.io/gorm"
  11. )
  12. func TestCreateKubeEvent(t *testing.T) {
  13. tester := &tester{
  14. dbFileName: "./porter_create_event.db",
  15. }
  16. setupTestEnv(tester, t)
  17. initProject(tester, t)
  18. initCluster(tester, t)
  19. defer cleanup(tester, t)
  20. event := &models.KubeEvent{
  21. ProjectID: tester.initProjects[0].Model.ID,
  22. ClusterID: tester.initClusters[0].Model.ID,
  23. Name: "pod-example-1",
  24. Namespace: "default",
  25. }
  26. copyKubeEvent := *event
  27. event, err := tester.repo.KubeEvent().CreateEvent(event)
  28. if err != nil {
  29. t.Fatalf("%v\n", err)
  30. }
  31. // append a sub event as well
  32. subEvent := &models.KubeSubEvent{
  33. EventType: "pod",
  34. Message: "Pod killed",
  35. Reason: "OOM: memory limit exceeded",
  36. Timestamp: time.Now(),
  37. }
  38. copySubEvent := *subEvent
  39. copySubEvent.KubeEventID = 1
  40. err = tester.repo.KubeEvent().AppendSubEvent(event, subEvent)
  41. if err != nil {
  42. t.Fatalf("%v\n", err)
  43. }
  44. copyKubeEvent.SubEvents = []models.KubeSubEvent{copySubEvent}
  45. event, err = tester.repo.KubeEvent().ReadEvent(event.Model.ID, 1, 1)
  46. if err != nil {
  47. t.Fatalf("%v\n", err)
  48. }
  49. // make sure id is 1 and name is "ecr"
  50. if event.Model.ID != 1 {
  51. t.Errorf("incorrect registry ID: expected %d, got %d\n", 1, event.Model.ID)
  52. }
  53. event.Model = gorm.Model{}
  54. event.SubEvents[0].Model = gorm.Model{}
  55. if diff := deep.Equal(event, &copyKubeEvent); diff != nil {
  56. t.Errorf("events not equal:")
  57. t.Error(diff)
  58. }
  59. }
  60. func TestReadKubeEventsByGroup(t *testing.T) {
  61. suffix, _ := encryption.GenerateRandomBytes(4)
  62. tester := &tester{
  63. dbFileName: fmt.Sprintf("./porter_read_event_%s.db", suffix),
  64. }
  65. setupTestEnv(tester, t)
  66. initProject(tester, t)
  67. initCluster(tester, t)
  68. initKubeEvents(tester, t)
  69. defer cleanup(tester, t)
  70. event, err := tester.repo.KubeEvent().ReadEventByGroup(
  71. tester.initProjects[0].Model.ID,
  72. tester.initClusters[0].Model.ID,
  73. &types.GroupOptions{
  74. Name: "pod-example-1",
  75. Namespace: "default",
  76. ResourceType: "pod",
  77. ThresholdTime: time.Now().Add(-15 * time.Minute),
  78. },
  79. )
  80. if err != nil {
  81. t.Fatalf("%v\n", err)
  82. }
  83. expKubeEvent := tester.initKubeEvents[1]
  84. if diff := deep.Equal(expKubeEvent, event); diff != nil {
  85. t.Errorf("incorrect events")
  86. t.Error(diff)
  87. }
  88. }
  89. func TestListKubeEventsByProjectIDWithLimit(t *testing.T) {
  90. suffix, _ := encryption.GenerateRandomBytes(4)
  91. tester := &tester{
  92. dbFileName: fmt.Sprintf("./porter_list_events_%s.db", suffix),
  93. }
  94. setupTestEnv(tester, t)
  95. initProject(tester, t)
  96. initCluster(tester, t)
  97. initKubeEvents(tester, t)
  98. defer cleanup(tester, t)
  99. testListKubeEventsByProjectID(tester, t, 1, true, &types.ListKubeEventRequest{
  100. Limit: 10,
  101. ResourceType: "node",
  102. }, tester.initKubeEvents[50:60])
  103. }
  104. func TestListKubeEventsByProjectIDWithSkip(t *testing.T) {
  105. suffix, _ := encryption.GenerateRandomBytes(4)
  106. tester := &tester{
  107. dbFileName: fmt.Sprintf("./porter_list_events_%s.db", suffix),
  108. }
  109. setupTestEnv(tester, t)
  110. initProject(tester, t)
  111. initCluster(tester, t)
  112. initKubeEvents(tester, t)
  113. defer cleanup(tester, t)
  114. testListKubeEventsByProjectID(tester, t, 1, true, &types.ListKubeEventRequest{
  115. Limit: 25,
  116. Skip: 10,
  117. }, tester.initKubeEvents[10:35])
  118. }
  119. func TestDeleteKubeEvents(t *testing.T) {
  120. suffix, _ := encryption.GenerateRandomBytes(4)
  121. tester := &tester{
  122. dbFileName: fmt.Sprintf("./porter_delete_events_%s.db", suffix),
  123. }
  124. setupTestEnv(tester, t)
  125. initProject(tester, t)
  126. initCluster(tester, t)
  127. initKubeEvents(tester, t)
  128. defer cleanup(tester, t)
  129. // delete a specific event and then test list again
  130. err := tester.repo.KubeEvent().DeleteEvent(11)
  131. if err != nil {
  132. t.Fatalf("%v\n", err)
  133. }
  134. testListKubeEventsByProjectID(tester, t, 1, true, &types.ListKubeEventRequest{
  135. Limit: 25,
  136. Skip: 10,
  137. }, tester.initKubeEvents[11:36])
  138. }
  139. func testListKubeEventsByProjectID(tester *tester, t *testing.T, clusterID uint, decrypt bool, opts *types.ListKubeEventRequest, expKubeEvents []*models.KubeEvent) {
  140. t.Helper()
  141. events, _, err := tester.repo.KubeEvent().ListEventsByProjectID(
  142. tester.initProjects[0].Model.ID,
  143. clusterID,
  144. opts,
  145. )
  146. if err != nil {
  147. t.Fatalf("%v\n", err)
  148. }
  149. // make sure data is correct
  150. if len(events) != len(expKubeEvents) {
  151. t.Fatalf("length of events incorrect: expected %d, got %d\n", len(expKubeEvents), len(events))
  152. }
  153. if diff := deep.Equal(expKubeEvents, events); diff != nil {
  154. t.Errorf("incorrect events")
  155. t.Error(diff)
  156. }
  157. }