metricsquerier_test.go 28 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031
  1. package collector
  2. import (
  3. "reflect"
  4. "testing"
  5. "time"
  6. "github.com/opencost/opencost/core/pkg/source"
  7. "github.com/opencost/opencost/core/pkg/util"
  8. "github.com/opencost/opencost/modules/collector-source/pkg/metric"
  9. "github.com/opencost/opencost/modules/collector-source/pkg/scrape"
  10. )
  11. var Start1Str = "2025-01-01T00:00:00Z"
  12. var End1Str = "2025-01-01T01:00:00Z"
  13. type MockStoreProvider struct {
  14. metricsCollector metric.MetricStore
  15. }
  16. func (m *MockStoreProvider) GetStore(start, end time.Time) metric.MetricStore {
  17. return m.metricsCollector
  18. }
  19. // QueryDataCoverage is not implemented for this mock
  20. func (m *MockStoreProvider) GetDailyDataCoverage(limitDays int) (time.Time, time.Time, error) {
  21. return time.Time{}, time.Time{}, nil
  22. }
  23. func GetMockCollectorProvider() StoreProvider {
  24. collector := NewOpenCostMetricStore()
  25. start, _ := time.Parse(time.RFC3339, Start1Str)
  26. time1 := time.Date(2025, 1, 1, 0, 30, 0, 0, time.UTC)
  27. end, _ := time.Parse(time.RFC3339, End1Str)
  28. node1Info := map[string]string{
  29. "node": "node1",
  30. "provider_id": "node1",
  31. }
  32. localStorage1Info := map[string]string{
  33. source.InstanceLabel: "node1",
  34. source.DeviceLabel: "local",
  35. }
  36. cluster1Info := map[string]string{
  37. "provisioner_name": "GKE",
  38. }
  39. gpu1Info := map[string]string{
  40. source.NamespaceLabel: "namespace1",
  41. source.PodLabel: "pod1",
  42. "container": "container1",
  43. "gpu": "0",
  44. "UUID": "GPU-1",
  45. "pci_bus_id": "00000000:00:0A.0",
  46. "device": "nvidia0",
  47. "modelName": "Tesla T4",
  48. "Hostname": "localhost",
  49. }
  50. pod1Info := map[string]string{
  51. source.NamespaceLabel: "namespace1",
  52. source.NodeLabel: "node1",
  53. source.InstanceLabel: "node1",
  54. source.PodLabel: "pod1",
  55. source.UIDLabel: "pod-uuid1",
  56. }
  57. container1Info := map[string]string{
  58. source.NamespaceLabel: "namespace1",
  59. source.NodeLabel: "node1",
  60. source.InstanceLabel: "node1",
  61. source.PodLabel: "pod1",
  62. source.UIDLabel: "pod-uuid1",
  63. source.ContainerLabel: "container1",
  64. }
  65. container2Info := map[string]string{
  66. source.NamespaceLabel: "kube-system",
  67. source.NodeLabel: "node1",
  68. source.InstanceLabel: "node1",
  69. source.PodLabel: "pod2",
  70. source.UIDLabel: "pod-uuid2",
  71. source.ContainerLabel: "container2",
  72. }
  73. networkZone1Info := map[string]string{
  74. source.PodNameLabel: "pod1",
  75. source.NamespaceLabel: "namespace1",
  76. source.InternetLabel: "false",
  77. source.SameRegionLabel: "true",
  78. source.SameZoneLabel: "false",
  79. source.ServiceLabel: "service1",
  80. }
  81. networkRegion1Info := map[string]string{
  82. source.PodNameLabel: "pod1",
  83. source.NamespaceLabel: "namespace1",
  84. source.InternetLabel: "false",
  85. source.SameRegionLabel: "false",
  86. source.SameZoneLabel: "false",
  87. source.ServiceLabel: "service1",
  88. }
  89. networkInternet1Info := map[string]string{
  90. source.PodNameLabel: "pod1",
  91. source.NamespaceLabel: "namespace1",
  92. source.InternetLabel: "true",
  93. source.SameRegionLabel: "false",
  94. source.SameZoneLabel: "false",
  95. source.ServiceLabel: "service1",
  96. }
  97. networkInternet2Info := map[string]string{
  98. source.PodNameLabel: "pod1",
  99. source.NamespaceLabel: "namespace1",
  100. source.InternetLabel: "true",
  101. source.SameRegionLabel: "false",
  102. source.SameZoneLabel: "false",
  103. source.ServiceLabel: "service2",
  104. }
  105. collector.Update(scrape.NodeTotalHourlyCost, node1Info, 0, start, nil)
  106. collector.Update(scrape.NodeTotalHourlyCost, node1Info, 0, end, nil)
  107. collector.Update(scrape.NodeFSCapacityBytes, localStorage1Info, 2*GiB, start, nil)
  108. collector.Update(scrape.ContainerFSUsageBytes, localStorage1Info, 1*GiB, start, nil)
  109. collector.Update(scrape.ContainerFSUsageBytes, localStorage1Info, 1*GiB, end, nil)
  110. collector.Update(scrape.KubeNodeStatusCapacityMemoryBytes, node1Info, 4*GiB, start, nil)
  111. collector.Update(scrape.ContainerMemoryWorkingSetBytes, container1Info, 1*GiB, start, nil)
  112. collector.Update(scrape.ContainerMemoryWorkingSetBytes, container2Info, 2*GiB, start, nil)
  113. collector.Update(scrape.ContainerCPUUsageSecondsTotal, container1Info, 0, start, nil)
  114. collector.Update(scrape.ContainerCPUUsageSecondsTotal, container1Info, 60*60*4, time1, nil)
  115. collector.Update(scrape.ContainerCPUUsageSecondsTotal, container1Info, 60*60*10, end, nil)
  116. collector.Update(scrape.KubecostClusterManagementCost, cluster1Info, 0.1, start, nil)
  117. collector.Update(scrape.KubecostClusterManagementCost, cluster1Info, 0.1, end, nil)
  118. collector.Update(scrape.DCGMFIDEVDECUTIL, gpu1Info, 0, start, nil)
  119. collector.Update(scrape.DCGMFIPROFGRENGINEACTIVE, gpu1Info, 0, start, nil)
  120. collector.Update(scrape.DCGMFIPROFGRENGINEACTIVE, gpu1Info, 1, end, nil)
  121. collector.Update(scrape.KubecostNetworkZoneEgressCost, nil, 1, start, nil)
  122. collector.Update(scrape.KubecostNetworkRegionEgressCost, nil, 2, start, nil)
  123. collector.Update(scrape.KubecostNetworkInternetEgressCost, nil, 3, start, nil)
  124. collector.Update(scrape.ContainerNetworkTransmitBytesTotal, pod1Info, 3*GiB, start, nil)
  125. collector.Update(scrape.ContainerNetworkTransmitBytesTotal, pod1Info, 13*GiB, end, nil)
  126. collector.Update(scrape.ContainerNetworkReceiveBytesTotal, pod1Info, 30*GiB, start, nil)
  127. collector.Update(scrape.ContainerNetworkReceiveBytesTotal, pod1Info, 130*GiB, end, nil)
  128. collector.Update(scrape.KubecostPodNetworkEgressBytesTotal, networkRegion1Info, 1*GiB, start, nil)
  129. collector.Update(scrape.KubecostPodNetworkEgressBytesTotal, networkZone1Info, 0*GiB, start, nil)
  130. collector.Update(scrape.KubecostPodNetworkEgressBytesTotal, networkInternet1Info, 1*GiB, start, nil)
  131. collector.Update(scrape.KubecostPodNetworkEgressBytesTotal, networkInternet2Info, 1*GiB, start, nil)
  132. collector.Update(scrape.KubecostPodNetworkEgressBytesTotal, networkRegion1Info, 2*GiB, end, nil)
  133. collector.Update(scrape.KubecostPodNetworkEgressBytesTotal, networkZone1Info, 2*GiB, end, nil)
  134. collector.Update(scrape.KubecostPodNetworkEgressBytesTotal, networkInternet1Info, 4*GiB, end, nil)
  135. collector.Update(scrape.KubecostPodNetworkEgressBytesTotal, networkInternet2Info, 5*GiB, end, nil)
  136. collector.Update(scrape.KubecostPodNetworkIngressBytesTotal, networkRegion1Info, 10*GiB, start, nil)
  137. collector.Update(scrape.KubecostPodNetworkIngressBytesTotal, networkZone1Info, 0*GiB, start, nil)
  138. collector.Update(scrape.KubecostPodNetworkIngressBytesTotal, networkInternet1Info, 10*GiB, start, nil)
  139. collector.Update(scrape.KubecostPodNetworkIngressBytesTotal, networkInternet2Info, 10*GiB, start, nil)
  140. collector.Update(scrape.KubecostPodNetworkIngressBytesTotal, networkRegion1Info, 20*GiB, end, nil)
  141. collector.Update(scrape.KubecostPodNetworkIngressBytesTotal, networkZone1Info, 20*GiB, end, nil)
  142. collector.Update(scrape.KubecostPodNetworkIngressBytesTotal, networkInternet1Info, 40*GiB, end, nil)
  143. collector.Update(scrape.KubecostPodNetworkIngressBytesTotal, networkInternet2Info, 50*GiB, end, nil)
  144. return &MockStoreProvider{
  145. metricsCollector: collector,
  146. }
  147. }
  148. func TestCollectorMetricsQuerier_QueryLocalStorageCost(t *testing.T) {
  149. start1, _ := time.Parse(time.RFC3339, Start1Str)
  150. end1, _ := time.Parse(time.RFC3339, End1Str)
  151. c := collectorMetricsQuerier{
  152. collectorProvider: GetMockCollectorProvider(),
  153. }
  154. resCh := c.QueryLocalStorageCost(start1, end1)
  155. res, err := resCh.Await()
  156. if err != nil {
  157. t.Errorf("unexpected error: %v", err.Error())
  158. }
  159. expected := []*source.LocalStorageCostResult{
  160. {
  161. Cluster: "",
  162. Instance: "node1",
  163. Device: "local",
  164. Data: []*util.Vector{
  165. {
  166. Value: LocalStorageCostPerGiBHr * 2,
  167. },
  168. },
  169. },
  170. }
  171. if len(res) != len(expected) {
  172. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  173. }
  174. for i, got := range res {
  175. if !reflect.DeepEqual(got, expected[i]) {
  176. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  177. }
  178. }
  179. }
  180. func TestCollectorMetricsQuerier_QueryLocalStorageUsedCost(t *testing.T) {
  181. start1, _ := time.Parse(time.RFC3339, Start1Str)
  182. end1, _ := time.Parse(time.RFC3339, End1Str)
  183. c := collectorMetricsQuerier{
  184. collectorProvider: GetMockCollectorProvider(),
  185. }
  186. resCh := c.QueryLocalStorageUsedCost(start1, end1)
  187. res, err := resCh.Await()
  188. if err != nil {
  189. t.Errorf("unexpected error: %v", err.Error())
  190. }
  191. expected := []*source.LocalStorageUsedCostResult{
  192. {
  193. Cluster: "",
  194. Instance: "node1",
  195. Device: "local",
  196. Data: []*util.Vector{
  197. {
  198. Value: LocalStorageCostPerGiBHr,
  199. },
  200. },
  201. },
  202. }
  203. if len(res) != len(expected) {
  204. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  205. }
  206. for i, got := range res {
  207. if !reflect.DeepEqual(got, expected[i]) {
  208. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  209. }
  210. }
  211. }
  212. func TestCollectorMetricsQuerier_QueryNodeActiveMinutes(t *testing.T) {
  213. start1, _ := time.Parse(time.RFC3339, Start1Str)
  214. end1, _ := time.Parse(time.RFC3339, End1Str)
  215. c := collectorMetricsQuerier{
  216. collectorProvider: GetMockCollectorProvider(),
  217. }
  218. resCh := c.QueryNodeActiveMinutes(time.Now(), time.Now())
  219. res, err := resCh.Await()
  220. if err != nil {
  221. t.Errorf("unexpected error: %v", err.Error())
  222. }
  223. expected := []*source.NodeActiveMinutesResult{
  224. {
  225. Cluster: "",
  226. Node: "node1",
  227. ProviderID: "node1",
  228. Data: []*util.Vector{
  229. {
  230. Timestamp: float64(start1.Unix()),
  231. Value: 1,
  232. },
  233. {
  234. Timestamp: float64(end1.Unix()),
  235. Value: 1,
  236. },
  237. },
  238. },
  239. }
  240. if len(res) != len(expected) {
  241. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  242. }
  243. for i, got := range res {
  244. if !reflect.DeepEqual(got, expected[i]) {
  245. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  246. }
  247. }
  248. }
  249. func TestCollectorMetricsQuerier_QueryNodeRAMSystemPercent(t *testing.T) {
  250. start1, _ := time.Parse(time.RFC3339, Start1Str)
  251. end1, _ := time.Parse(time.RFC3339, End1Str)
  252. c := collectorMetricsQuerier{
  253. collectorProvider: GetMockCollectorProvider(),
  254. }
  255. resCh := c.QueryNodeRAMSystemPercent(start1, end1)
  256. res, err := resCh.Await()
  257. if err != nil {
  258. t.Errorf("unexpected error: %v", err.Error())
  259. }
  260. expected := []*source.NodeRAMSystemPercentResult{
  261. {
  262. Cluster: "",
  263. Instance: "node1",
  264. Data: []*util.Vector{
  265. {
  266. Value: .5,
  267. },
  268. },
  269. },
  270. }
  271. if len(res) != len(expected) {
  272. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  273. }
  274. for i, got := range res {
  275. if !reflect.DeepEqual(got, expected[i]) {
  276. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  277. }
  278. }
  279. }
  280. func TestCollectorMetricsQuerier_QueryNodeRAMUserPercent(t *testing.T) {
  281. start1, _ := time.Parse(time.RFC3339, Start1Str)
  282. end1, _ := time.Parse(time.RFC3339, End1Str)
  283. c := collectorMetricsQuerier{
  284. collectorProvider: GetMockCollectorProvider(),
  285. }
  286. resCh := c.QueryNodeRAMUserPercent(start1, end1)
  287. res, err := resCh.Await()
  288. if err != nil {
  289. t.Errorf("unexpected error: %v", err.Error())
  290. }
  291. expected := []*source.NodeRAMUserPercentResult{
  292. {
  293. Cluster: "",
  294. Instance: "node1",
  295. Data: []*util.Vector{
  296. {
  297. Value: .25,
  298. },
  299. },
  300. },
  301. }
  302. if len(res) != len(expected) {
  303. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  304. }
  305. for i, got := range res {
  306. if !reflect.DeepEqual(got, expected[i]) {
  307. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  308. }
  309. }
  310. }
  311. func TestCollectorMetricsQuerier_QueryClusterManagementDuration(t *testing.T) {
  312. start1, _ := time.Parse(time.RFC3339, Start1Str)
  313. end1, _ := time.Parse(time.RFC3339, End1Str)
  314. c := collectorMetricsQuerier{
  315. collectorProvider: GetMockCollectorProvider(),
  316. }
  317. resCh := c.QueryClusterManagementDuration(start1, end1)
  318. res, err := resCh.Await()
  319. if err != nil {
  320. t.Errorf("unexpected error: %v", err.Error())
  321. }
  322. expected := []*source.ClusterManagementDurationResult{
  323. {
  324. Cluster: "",
  325. Provisioner: "GKE",
  326. Data: []*util.Vector{
  327. {
  328. Timestamp: float64(start1.Unix()),
  329. Value: 1,
  330. },
  331. {
  332. Timestamp: float64(end1.Unix()),
  333. Value: 1,
  334. },
  335. },
  336. },
  337. }
  338. if len(res) != len(expected) {
  339. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  340. }
  341. for i, got := range res {
  342. if !reflect.DeepEqual(got, expected[i]) {
  343. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  344. }
  345. }
  346. }
  347. func Test_collectorMetricsQuerier_QueryCPUUsageAvg(t *testing.T) {
  348. start1, _ := time.Parse(time.RFC3339, Start1Str)
  349. end1, _ := time.Parse(time.RFC3339, End1Str)
  350. c := collectorMetricsQuerier{
  351. collectorProvider: GetMockCollectorProvider(),
  352. }
  353. resCh := c.QueryCPUUsageAvg(start1, end1)
  354. res, err := resCh.Await()
  355. if err != nil {
  356. t.Errorf("unexpected error: %v", err.Error())
  357. }
  358. expected := []*source.CPUUsageAvgResult{
  359. {
  360. Cluster: "",
  361. Namespace: "namespace1",
  362. Node: "node1",
  363. Instance: "node1",
  364. Pod: "pod1",
  365. Container: "container1",
  366. Data: []*util.Vector{
  367. {
  368. Value: 10,
  369. },
  370. },
  371. },
  372. }
  373. if len(res) != len(expected) {
  374. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  375. }
  376. for i, got := range res {
  377. if !reflect.DeepEqual(got, expected[i]) {
  378. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  379. }
  380. }
  381. }
  382. func Test_collectorMetricsQuerier_QueryCPUUsageMax(t *testing.T) {
  383. start1, _ := time.Parse(time.RFC3339, Start1Str)
  384. end1, _ := time.Parse(time.RFC3339, End1Str)
  385. c := collectorMetricsQuerier{
  386. collectorProvider: GetMockCollectorProvider(),
  387. }
  388. resCh := c.QueryCPUUsageMax(start1, end1)
  389. res, err := resCh.Await()
  390. if err != nil {
  391. t.Errorf("unexpected error: %v", err.Error())
  392. }
  393. expected := []*source.CPUUsageMaxResult{
  394. {
  395. Cluster: "",
  396. Namespace: "namespace1",
  397. Node: "node1",
  398. Instance: "node1",
  399. Pod: "pod1",
  400. Container: "container1",
  401. Data: []*util.Vector{
  402. {
  403. Value: 12,
  404. },
  405. },
  406. },
  407. }
  408. if len(res) != len(expected) {
  409. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  410. }
  411. for i, got := range res {
  412. if !reflect.DeepEqual(got, expected[i]) {
  413. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  414. }
  415. }
  416. }
  417. func TestCollectorMetricsQuerier_QueryGPUsUsageAvg(t *testing.T) {
  418. start1, _ := time.Parse(time.RFC3339, Start1Str)
  419. end1, _ := time.Parse(time.RFC3339, End1Str)
  420. c := collectorMetricsQuerier{
  421. collectorProvider: GetMockCollectorProvider(),
  422. }
  423. resCh := c.QueryGPUsUsageAvg(start1, end1)
  424. res, err := resCh.Await()
  425. if err != nil {
  426. t.Errorf("unexpected error: %v", err.Error())
  427. }
  428. expected := []*source.GPUsUsageAvgResult{
  429. {
  430. Cluster: "",
  431. Namespace: "namespace1",
  432. Pod: "pod1",
  433. Container: "container1",
  434. Data: []*util.Vector{
  435. {
  436. Value: 0.5,
  437. },
  438. },
  439. },
  440. }
  441. if len(res) != len(expected) {
  442. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  443. }
  444. for i, got := range res {
  445. if !reflect.DeepEqual(got, expected[i]) {
  446. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  447. }
  448. }
  449. }
  450. func TestCollectorMetricsQuerier_QueryGPUsUsageMax(t *testing.T) {
  451. start1, _ := time.Parse(time.RFC3339, Start1Str)
  452. end1, _ := time.Parse(time.RFC3339, End1Str)
  453. c := collectorMetricsQuerier{
  454. collectorProvider: GetMockCollectorProvider(),
  455. }
  456. resCh := c.QueryGPUsUsageMax(start1, end1)
  457. res, err := resCh.Await()
  458. if err != nil {
  459. t.Errorf("unexpected error: %v", err.Error())
  460. }
  461. expected := []*source.GPUsUsageMaxResult{
  462. {
  463. Cluster: "",
  464. Namespace: "namespace1",
  465. Pod: "pod1",
  466. Container: "container1",
  467. Data: []*util.Vector{
  468. {
  469. Value: 1.0,
  470. },
  471. },
  472. },
  473. }
  474. if len(res) != len(expected) {
  475. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  476. }
  477. for i, got := range res {
  478. if !reflect.DeepEqual(got, expected[i]) {
  479. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  480. }
  481. }
  482. }
  483. func TestCollectorMetricsQuerier_QueryGPUInfo(t *testing.T) {
  484. start1, _ := time.Parse(time.RFC3339, Start1Str)
  485. end1, _ := time.Parse(time.RFC3339, End1Str)
  486. c := collectorMetricsQuerier{
  487. collectorProvider: GetMockCollectorProvider(),
  488. }
  489. resCh := c.QueryGPUInfo(start1, end1)
  490. res, err := resCh.Await()
  491. if err != nil {
  492. t.Errorf("unexpected error: %v", err.Error())
  493. }
  494. expected := []*source.GPUInfoResult{
  495. {
  496. Cluster: "",
  497. Namespace: "namespace1",
  498. Pod: "pod1",
  499. Container: "container1",
  500. Device: "nvidia0",
  501. ModelName: "Tesla T4",
  502. UUID: "GPU-1",
  503. Data: []*util.Vector{
  504. {
  505. Value: 1,
  506. },
  507. },
  508. },
  509. }
  510. if len(res) != len(expected) {
  511. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  512. }
  513. for i, got := range res {
  514. if !reflect.DeepEqual(got, expected[i]) {
  515. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  516. }
  517. }
  518. }
  519. func Test_collectorMetricsQuerier_QueryNetZoneGiB(t *testing.T) {
  520. start1, _ := time.Parse(time.RFC3339, Start1Str)
  521. end1, _ := time.Parse(time.RFC3339, End1Str)
  522. c := collectorMetricsQuerier{
  523. collectorProvider: GetMockCollectorProvider(),
  524. }
  525. resCh := c.QueryNetZoneGiB(start1, end1)
  526. res, err := resCh.Await()
  527. if err != nil {
  528. t.Errorf("unexpected error: %v", err.Error())
  529. }
  530. expected := []*source.NetZoneGiBResult{
  531. {
  532. Cluster: "",
  533. Namespace: "namespace1",
  534. Pod: "pod1",
  535. Data: []*util.Vector{
  536. {
  537. Value: 2,
  538. },
  539. },
  540. },
  541. }
  542. if len(res) != len(expected) {
  543. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  544. }
  545. for i, got := range res {
  546. if !reflect.DeepEqual(got, expected[i]) {
  547. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  548. }
  549. }
  550. }
  551. func Test_collectorMetricsQuerier_QueryNetZonePricePerGiB(t *testing.T) {
  552. start1, _ := time.Parse(time.RFC3339, Start1Str)
  553. end1, _ := time.Parse(time.RFC3339, End1Str)
  554. c := collectorMetricsQuerier{
  555. collectorProvider: GetMockCollectorProvider(),
  556. }
  557. resCh := c.QueryNetZonePricePerGiB(start1, end1)
  558. res, err := resCh.Await()
  559. if err != nil {
  560. t.Errorf("unexpected error: %v", err.Error())
  561. }
  562. expected := []*source.NetZonePricePerGiBResult{
  563. {
  564. Cluster: "",
  565. Data: []*util.Vector{
  566. {
  567. Value: 1,
  568. },
  569. },
  570. },
  571. }
  572. if len(res) != len(expected) {
  573. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  574. }
  575. for i, got := range res {
  576. if !reflect.DeepEqual(got, expected[i]) {
  577. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  578. }
  579. }
  580. }
  581. func Test_collectorMetricsQuerier_QueryNetRegionGiB(t *testing.T) {
  582. start1, _ := time.Parse(time.RFC3339, Start1Str)
  583. end1, _ := time.Parse(time.RFC3339, End1Str)
  584. c := collectorMetricsQuerier{
  585. collectorProvider: GetMockCollectorProvider(),
  586. }
  587. resCh := c.QueryNetRegionGiB(start1, end1)
  588. res, err := resCh.Await()
  589. if err != nil {
  590. t.Errorf("unexpected error: %v", err.Error())
  591. }
  592. expected := []*source.NetRegionGiBResult{
  593. {
  594. Cluster: "",
  595. Namespace: "namespace1",
  596. Pod: "pod1",
  597. Data: []*util.Vector{
  598. {
  599. Value: 1,
  600. },
  601. },
  602. },
  603. }
  604. if len(res) != len(expected) {
  605. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  606. }
  607. for i, got := range res {
  608. if !reflect.DeepEqual(got, expected[i]) {
  609. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  610. }
  611. }
  612. }
  613. func Test_collectorMetricsQuerier_QueryNetRegionPricePerGiB(t *testing.T) {
  614. start1, _ := time.Parse(time.RFC3339, Start1Str)
  615. end1, _ := time.Parse(time.RFC3339, End1Str)
  616. c := collectorMetricsQuerier{
  617. collectorProvider: GetMockCollectorProvider(),
  618. }
  619. resCh := c.QueryNetRegionPricePerGiB(start1, end1)
  620. res, err := resCh.Await()
  621. if err != nil {
  622. t.Errorf("unexpected error: %v", err.Error())
  623. }
  624. expected := []*source.NetRegionPricePerGiBResult{
  625. {
  626. Cluster: "",
  627. Data: []*util.Vector{
  628. {
  629. Value: 2,
  630. },
  631. },
  632. },
  633. }
  634. if len(res) != len(expected) {
  635. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  636. }
  637. for i, got := range res {
  638. if !reflect.DeepEqual(got, expected[i]) {
  639. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  640. }
  641. }
  642. }
  643. func Test_collectorMetricsQuerier_QueryNetInternetGiB(t *testing.T) {
  644. start1, _ := time.Parse(time.RFC3339, Start1Str)
  645. end1, _ := time.Parse(time.RFC3339, End1Str)
  646. c := collectorMetricsQuerier{
  647. collectorProvider: GetMockCollectorProvider(),
  648. }
  649. resCh := c.QueryNetInternetGiB(start1, end1)
  650. res, err := resCh.Await()
  651. if err != nil {
  652. t.Errorf("unexpected error: %v", err.Error())
  653. }
  654. expected := []*source.NetInternetGiBResult{
  655. {
  656. Cluster: "",
  657. Namespace: "namespace1",
  658. Pod: "pod1",
  659. Data: []*util.Vector{
  660. {
  661. Value: 7,
  662. },
  663. },
  664. },
  665. }
  666. if len(res) != len(expected) {
  667. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  668. }
  669. for i, got := range res {
  670. if !reflect.DeepEqual(got, expected[i]) {
  671. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  672. }
  673. }
  674. }
  675. func Test_collectorMetricsQuerier_QueryNetInternetPricePerGiB(t *testing.T) {
  676. start1, _ := time.Parse(time.RFC3339, Start1Str)
  677. end1, _ := time.Parse(time.RFC3339, End1Str)
  678. c := collectorMetricsQuerier{
  679. collectorProvider: GetMockCollectorProvider(),
  680. }
  681. resCh := c.QueryNetInternetPricePerGiB(start1, end1)
  682. res, err := resCh.Await()
  683. if err != nil {
  684. t.Errorf("unexpected error: %v", err.Error())
  685. }
  686. expected := []*source.NetInternetPricePerGiBResult{
  687. {
  688. Cluster: "",
  689. Data: []*util.Vector{
  690. {
  691. Value: 3,
  692. },
  693. },
  694. },
  695. }
  696. if len(res) != len(expected) {
  697. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  698. }
  699. for i, got := range res {
  700. if !reflect.DeepEqual(got, expected[i]) {
  701. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  702. }
  703. }
  704. }
  705. func Test_collectorMetricsQuerier_QueryNetInternetServiceGiB(t *testing.T) {
  706. start1, _ := time.Parse(time.RFC3339, Start1Str)
  707. end1, _ := time.Parse(time.RFC3339, End1Str)
  708. c := collectorMetricsQuerier{
  709. collectorProvider: GetMockCollectorProvider(),
  710. }
  711. resCh := c.QueryNetInternetServiceGiB(start1, end1)
  712. res, err := resCh.Await()
  713. if err != nil {
  714. t.Errorf("unexpected error: %v", err.Error())
  715. }
  716. expected := []*source.NetInternetServiceGiBResult{
  717. {
  718. Cluster: "",
  719. Namespace: "namespace1",
  720. Pod: "pod1",
  721. Service: "service1",
  722. Data: []*util.Vector{
  723. {
  724. Value: 3,
  725. },
  726. },
  727. },
  728. {
  729. Cluster: "",
  730. Namespace: "namespace1",
  731. Pod: "pod1",
  732. Service: "service2",
  733. Data: []*util.Vector{
  734. {
  735. Value: 4,
  736. },
  737. },
  738. },
  739. }
  740. if len(res) != len(expected) {
  741. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  742. }
  743. for i, got := range res {
  744. if !reflect.DeepEqual(got, expected[i]) {
  745. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  746. }
  747. }
  748. }
  749. func Test_collectorMetricsQuerier_QueryNetTransferBytes(t *testing.T) {
  750. start1, _ := time.Parse(time.RFC3339, Start1Str)
  751. end1, _ := time.Parse(time.RFC3339, End1Str)
  752. c := collectorMetricsQuerier{
  753. collectorProvider: GetMockCollectorProvider(),
  754. }
  755. resCh := c.QueryNetTransferBytes(start1, end1)
  756. res, err := resCh.Await()
  757. if err != nil {
  758. t.Errorf("unexpected error: %v", err.Error())
  759. }
  760. expected := []*source.NetTransferBytesResult{
  761. {
  762. Cluster: "",
  763. Namespace: "namespace1",
  764. Pod: "pod1",
  765. Data: []*util.Vector{
  766. {
  767. Value: 10 * GiB,
  768. },
  769. },
  770. },
  771. }
  772. if len(res) != len(expected) {
  773. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  774. }
  775. for i, got := range res {
  776. if !reflect.DeepEqual(got, expected[i]) {
  777. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  778. }
  779. }
  780. }
  781. func Test_collectorMetricsQuerier_QueryNetZoneIngressGiB(t *testing.T) {
  782. start1, _ := time.Parse(time.RFC3339, Start1Str)
  783. end1, _ := time.Parse(time.RFC3339, End1Str)
  784. c := collectorMetricsQuerier{
  785. collectorProvider: GetMockCollectorProvider(),
  786. }
  787. resCh := c.QueryNetZoneIngressGiB(start1, end1)
  788. res, err := resCh.Await()
  789. if err != nil {
  790. t.Errorf("unexpected error: %v", err.Error())
  791. }
  792. expected := []*source.NetZoneIngressGiBResult{
  793. {
  794. Cluster: "",
  795. Namespace: "namespace1",
  796. Pod: "pod1",
  797. Data: []*util.Vector{
  798. {
  799. Value: 20,
  800. },
  801. },
  802. },
  803. }
  804. if len(res) != len(expected) {
  805. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  806. }
  807. for i, got := range res {
  808. if !reflect.DeepEqual(got, expected[i]) {
  809. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  810. }
  811. }
  812. }
  813. func Test_collectorMetricsQuerier_QueryNetRegionIngressGiB(t *testing.T) {
  814. start1, _ := time.Parse(time.RFC3339, Start1Str)
  815. end1, _ := time.Parse(time.RFC3339, End1Str)
  816. c := collectorMetricsQuerier{
  817. collectorProvider: GetMockCollectorProvider(),
  818. }
  819. resCh := c.QueryNetRegionIngressGiB(start1, end1)
  820. res, err := resCh.Await()
  821. if err != nil {
  822. t.Errorf("unexpected error: %v", err.Error())
  823. }
  824. expected := []*source.NetRegionIngressGiBResult{
  825. {
  826. Cluster: "",
  827. Namespace: "namespace1",
  828. Pod: "pod1",
  829. Data: []*util.Vector{
  830. {
  831. Value: 10,
  832. },
  833. },
  834. },
  835. }
  836. if len(res) != len(expected) {
  837. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  838. }
  839. for i, got := range res {
  840. if !reflect.DeepEqual(got, expected[i]) {
  841. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  842. }
  843. }
  844. }
  845. func Test_collectorMetricsQuerier_QueryNetInternetIngressGiB(t *testing.T) {
  846. start1, _ := time.Parse(time.RFC3339, Start1Str)
  847. end1, _ := time.Parse(time.RFC3339, End1Str)
  848. c := collectorMetricsQuerier{
  849. collectorProvider: GetMockCollectorProvider(),
  850. }
  851. resCh := c.QueryNetInternetIngressGiB(start1, end1)
  852. res, err := resCh.Await()
  853. if err != nil {
  854. t.Errorf("unexpected error: %v", err.Error())
  855. }
  856. expected := []*source.NetInternetIngressGiBResult{
  857. {
  858. Cluster: "",
  859. Namespace: "namespace1",
  860. Pod: "pod1",
  861. Data: []*util.Vector{
  862. {
  863. Value: 70,
  864. },
  865. },
  866. },
  867. }
  868. if len(res) != len(expected) {
  869. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  870. }
  871. for i, got := range res {
  872. if !reflect.DeepEqual(got, expected[i]) {
  873. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  874. }
  875. }
  876. }
  877. func Test_collectorMetricsQuerier_QueryNetInternetServiceIngressGiB(t *testing.T) {
  878. start1, _ := time.Parse(time.RFC3339, Start1Str)
  879. end1, _ := time.Parse(time.RFC3339, End1Str)
  880. c := collectorMetricsQuerier{
  881. collectorProvider: GetMockCollectorProvider(),
  882. }
  883. resCh := c.QueryNetInternetServiceIngressGiB(start1, end1)
  884. res, err := resCh.Await()
  885. if err != nil {
  886. t.Errorf("unexpected error: %v", err.Error())
  887. }
  888. expected := []*source.NetInternetServiceIngressGiBResult{
  889. {
  890. Cluster: "",
  891. Namespace: "namespace1",
  892. Pod: "pod1",
  893. Service: "service1",
  894. Data: []*util.Vector{
  895. {
  896. Value: 30,
  897. },
  898. },
  899. },
  900. {
  901. Cluster: "",
  902. Namespace: "namespace1",
  903. Pod: "pod1",
  904. Service: "service2",
  905. Data: []*util.Vector{
  906. {
  907. Value: 40,
  908. },
  909. },
  910. },
  911. }
  912. if len(res) != len(expected) {
  913. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  914. }
  915. for i, got := range res {
  916. if !reflect.DeepEqual(got, expected[i]) {
  917. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  918. }
  919. }
  920. }
  921. func Test_collectorMetricsQuerier_QueryNetReceiveBytes(t *testing.T) {
  922. start1, _ := time.Parse(time.RFC3339, Start1Str)
  923. end1, _ := time.Parse(time.RFC3339, End1Str)
  924. c := collectorMetricsQuerier{
  925. collectorProvider: GetMockCollectorProvider(),
  926. }
  927. resCh := c.QueryNetReceiveBytes(start1, end1)
  928. res, err := resCh.Await()
  929. if err != nil {
  930. t.Errorf("unexpected error: %v", err.Error())
  931. }
  932. expected := []*source.NetReceiveBytesResult{
  933. {
  934. Cluster: "",
  935. Namespace: "namespace1",
  936. Pod: "pod1",
  937. Data: []*util.Vector{
  938. {
  939. Value: 100 * GiB,
  940. },
  941. },
  942. },
  943. }
  944. if len(res) != len(expected) {
  945. t.Errorf("length of result was not as expected: got = %d, want %d", len(res), len(expected))
  946. }
  947. for i, got := range res {
  948. if !reflect.DeepEqual(got, expected[i]) {
  949. t.Errorf("result at index %d did not match: got = %v, want %v", i, got, expected[i])
  950. }
  951. }
  952. }