diff --git a/image/image.go b/image/image.go index fbb6e179df..717c8eb0de 100644 --- a/image/image.go +++ b/image/image.go @@ -282,14 +282,8 @@ type ByCreatedDesc []Info func (is ByCreatedDesc) Len() int { return len(is) } func (is ByCreatedDesc) Swap(i, j int) { is[i], is[j] = is[j], is[i] } func (is ByCreatedDesc) Less(i, j int) bool { - switch { - case is[i].CreatedAt.IsZero(): - return true - case is[j].CreatedAt.IsZero(): - return false - case is[i].CreatedAt.Equal(is[j].CreatedAt): + if is[i].CreatedAt.Equal(is[j].CreatedAt) { return is[i].ID.String() < is[j].ID.String() - default: - return is[i].CreatedAt.After(is[j].CreatedAt) } + return is[i].CreatedAt.After(is[j].CreatedAt) } diff --git a/image/image_test.go b/image/image_test.go index f3a6eb6f25..ed87957f8b 100644 --- a/image/image_test.go +++ b/image/image_test.go @@ -183,13 +183,28 @@ func TestImageInfoCreatedAtZero(t *testing.T) { func TestImage_OrderByCreationDate(t *testing.T) { time0 := testTime.Add(time.Second) time2 := testTime.Add(-time.Second) - imA := mustMakeInfo("my/Image:3", testTime) - imB := mustMakeInfo("my/Image:1", time0) - imC := mustMakeInfo("my/Image:4", time2) - imD := mustMakeInfo("my/Image:0", time.Time{}) // test nil - imE := mustMakeInfo("my/Image:2", testTime) // test equal - imgs := []Info{imA, imB, imC, imD, imE} + imA := mustMakeInfo("my/Image:2", testTime) + imB := mustMakeInfo("my/Image:0", time0) + imC := mustMakeInfo("my/Image:3", time2) + imD := mustMakeInfo("my/Image:4", time.Time{}) // test nil + imE := mustMakeInfo("my/Image:1", testTime) // test equal + imF := mustMakeInfo("my/Image:5", time.Time{}) // test nil equal + imgs := []Info{imA, imB, imC, imD, imE, imF} sort.Sort(ByCreatedDesc(imgs)) + checkSorted(t, imgs) + // now check stability + sort.Sort(ByCreatedDesc(imgs)) + checkSorted(t, imgs) + // more stability checks + for i := len(imgs)/2 - 1; i >= 0; i-- { + opp := len(imgs) - 1 - i + imgs[i], imgs[opp] = imgs[opp], imgs[i] + } + sort.Sort(ByCreatedDesc(imgs)) + checkSorted(t, imgs) +} + +func checkSorted(t *testing.T, imgs []Info) { for i, im := range imgs { if strconv.Itoa(i) != im.ID.Tag { for j, jim := range imgs {