diff_test.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. package kubecost
  2. import (
  3. "reflect"
  4. "testing"
  5. "time"
  6. )
  7. func TestDiff(t *testing.T) {
  8. start := time.Now().AddDate(0, 0, -1)
  9. end := time.Now()
  10. window1 := NewWindow(&start, &end)
  11. node1 := NewNode("node1", "cluster1", "123abc", start, end, window1)
  12. node1.CPUCost = 10
  13. node1b := node1.Clone().(*Node)
  14. node1b.CPUCost = 20
  15. node1Key, _ := key(node1, nil)
  16. node2 := NewNode("node2", "cluster1", "123abc", start, end, window1)
  17. node2Key, _ := key(node2, nil)
  18. node3 := NewNode("node3", "cluster1", "123abc", start, end, window1)
  19. node3Key, _ := key(node3, nil)
  20. node4 := NewNode("node4", "cluster1", "123abc", start, end, window1)
  21. node4Key, _ := key(node4, nil)
  22. disk1 := NewDisk("disk1", "cluster1", "123abc", start, end, window1)
  23. disk1Key, _ := key(disk1, nil)
  24. disk2 := NewDisk("disk2", "cluster1", "123abc", start, end, window1)
  25. disk2Key, _ := key(disk2, nil)
  26. cases := map[string]struct {
  27. inputAssetsBefore []Asset
  28. inputAssetsAfter []Asset
  29. test []Node
  30. costChange []int
  31. expected map[string]Diff[Asset]
  32. }{
  33. "added node": {
  34. inputAssetsBefore: []Asset{node1, node2},
  35. inputAssetsAfter: []Asset{node1, node2, node3},
  36. costChange: []int{},
  37. expected: map[string]Diff[Asset]{node3Key: {node3, DiffAdded}},
  38. },
  39. "multiple adds": {
  40. inputAssetsBefore: []Asset{node1, node2},
  41. inputAssetsAfter: []Asset{node1, node2, node3, node4},
  42. costChange: []int{},
  43. expected: map[string]Diff[Asset]{node3Key: {node3, DiffAdded}, node4Key: {node4, DiffAdded}},
  44. },
  45. "removed node": {
  46. inputAssetsBefore: []Asset{node1, node2},
  47. inputAssetsAfter: []Asset{node2},
  48. costChange: []int{},
  49. expected: map[string]Diff[Asset]{node1Key: {node1, DiffRemoved}},
  50. },
  51. "multiple removes": {
  52. inputAssetsBefore: []Asset{node1, node2, node3},
  53. inputAssetsAfter: []Asset{node2},
  54. costChange: []int{},
  55. expected: map[string]Diff[Asset]{node1Key: {node1, DiffRemoved}, node3Key: {node3, DiffRemoved}},
  56. },
  57. "remove all": {
  58. inputAssetsBefore: []Asset{node1, node2},
  59. inputAssetsAfter: []Asset{},
  60. costChange: []int{},
  61. expected: map[string]Diff[Asset]{node1Key: {node1, DiffRemoved}, node2Key: {node2, DiffRemoved}},
  62. },
  63. "add and remove": {
  64. inputAssetsBefore: []Asset{node1, node2},
  65. inputAssetsAfter: []Asset{node2, node3},
  66. costChange: []int{},
  67. expected: map[string]Diff[Asset]{node1Key: {node1, DiffRemoved}, node3Key: {node3, DiffAdded}},
  68. },
  69. "no change": {
  70. inputAssetsBefore: []Asset{node1, node2},
  71. inputAssetsAfter: []Asset{node1, node2},
  72. costChange: []int{},
  73. expected: map[string]Diff[Asset]{},
  74. },
  75. "order switch": {
  76. inputAssetsBefore: []Asset{node2, node1},
  77. inputAssetsAfter: []Asset{node1, node2},
  78. costChange: []int{},
  79. expected: map[string]Diff[Asset]{},
  80. },
  81. "disk add": {
  82. inputAssetsBefore: []Asset{disk1, node1},
  83. inputAssetsAfter: []Asset{disk1, node1, disk2},
  84. costChange: []int{},
  85. expected: map[string]Diff[Asset]{disk2Key: {disk2, DiffAdded}},
  86. },
  87. "disk and node add": {
  88. inputAssetsBefore: []Asset{disk1, node1},
  89. inputAssetsAfter: []Asset{disk1, node1, disk2, node2},
  90. costChange: []int{},
  91. expected: map[string]Diff[Asset]{disk2Key: {disk2, DiffAdded}, node2Key: {node2, DiffAdded}},
  92. },
  93. "disk and node removed": {
  94. inputAssetsBefore: []Asset{disk1, node1, disk2, node2},
  95. inputAssetsAfter: []Asset{disk2, node2},
  96. costChange: []int{},
  97. expected: map[string]Diff[Asset]{disk1Key: {disk1, DiffRemoved}, node1Key: {node1, DiffRemoved}},
  98. },
  99. "cost change": {
  100. inputAssetsBefore: []Asset{node1},
  101. inputAssetsAfter: []Asset{node1b},
  102. expected: map[string]Diff[Asset]{node1Key: {node1, DiffChanged}},
  103. },
  104. }
  105. for name, tc := range cases {
  106. t.Run(name, func(t *testing.T) {
  107. as1 := NewAssetSet(start, end, tc.inputAssetsBefore...)
  108. as2 := NewAssetSet(start, end, tc.inputAssetsAfter...)
  109. result := DiffAsset(as1.Clone(), as2.Clone())
  110. if !reflect.DeepEqual(result, tc.expected) {
  111. t.Fatalf("expected %+v; got %+v", tc.expected, result)
  112. }
  113. })
  114. }
  115. }