Commit ca61a72
authored
chore: use k8s equality package to compare structs instead of reflect (aws-controllers-k8s#653)
Description of changes:
Replace `reflect.DeepEqual` with `equality.Semantic.DeepEqual` from
`k8s.io/apimachinery/pkg/api/equality` for comparing Kubernetes objects.
Why this change:
1. Nil vs Empty equivalence: Semantic equality treats nil slices/maps
as equal to empty slices/maps. This prevents false negatives when
comparing API objects where nil and empty are semantically identical.
2. Proper time.Time comparison: Uses time.Time.Equal() internally,
which correctly compares timestamps across different timezone
representations and monotonic clock readings.
Example of the problem:
- `reflect.DeepEqual([]string{}, nil)` => false
- `equality.Semantic.DeepEqual([]string{}, nil)` => true
Both serialize to the same JSON/YAML, so they should be considered equal
when comparing Kubernetes resources.
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.1 parent 43713d4 commit ca61a72
3 files changed
Lines changed: 8 additions & 9 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
140 | 140 | | |
141 | 141 | | |
142 | 142 | | |
143 | | - | |
| 143 | + | |
144 | 144 | | |
145 | 145 | | |
146 | 146 | | |
147 | | - | |
| 147 | + | |
148 | 148 | | |
149 | 149 | | |
150 | 150 | | |
| |||
425 | 425 | | |
426 | 426 | | |
427 | 427 | | |
428 | | - | |
| 428 | + | |
429 | 429 | | |
430 | 430 | | |
431 | 431 | | |
| |||
497 | 497 | | |
498 | 498 | | |
499 | 499 | | |
500 | | - | |
| 500 | + | |
501 | 501 | | |
502 | 502 | | |
503 | 503 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
97 | 97 | | |
98 | 98 | | |
99 | 99 | | |
100 | | - | |
| 100 | + | |
101 | 101 | | |
102 | 102 | | |
103 | 103 | | |
| |||
274 | 274 | | |
275 | 275 | | |
276 | 276 | | |
277 | | - | |
| 277 | + | |
278 | 278 | | |
279 | 279 | | |
280 | 280 | | |
| |||
485 | 485 | | |
486 | 486 | | |
487 | 487 | | |
488 | | - | |
| 488 | + | |
489 | 489 | | |
490 | 490 | | |
491 | 491 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
7 | | - | |
8 | 7 | | |
| 8 | + | |
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
16 | | - | |
17 | 16 | | |
18 | 17 | | |
19 | 18 | | |
| |||
0 commit comments