// Copyright 2023 The Ebitengine Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package restorable_test import ( "image" "testing" "github.com/hajimehoshi/ebiten/v2/internal/restorable" ) func areEqualRectangles(a, b []image.Rectangle) bool { if len(a) != len(b) { return false } for i := range a { if a[i] != b[i] { return false } } return true } func TestRemoveDuplicatedRegions(t *testing.T) { cases := []struct { Regions []image.Rectangle NewRegions []image.Rectangle Expected []image.Rectangle }{ { Regions: nil, NewRegions: nil, Expected: nil, }, { NewRegions: []image.Rectangle{ image.Rect(0, 0, 2, 2), }, Expected: []image.Rectangle{ image.Rect(0, 0, 2, 2), }, }, { NewRegions: []image.Rectangle{ image.Rect(0, 0, 2, 2), image.Rect(0, 0, 1, 1), }, Expected: []image.Rectangle{ image.Rect(0, 0, 2, 2), }, }, { NewRegions: []image.Rectangle{ image.Rect(0, 0, 1, 1), image.Rect(0, 0, 2, 2), }, Expected: []image.Rectangle{ image.Rect(0, 0, 2, 2), }, }, { NewRegions: []image.Rectangle{ image.Rect(0, 0, 1, 3), image.Rect(0, 0, 2, 2), image.Rect(0, 0, 3, 1), }, Expected: []image.Rectangle{ image.Rect(0, 0, 1, 3), image.Rect(0, 0, 2, 2), image.Rect(0, 0, 3, 1), }, }, { NewRegions: []image.Rectangle{ image.Rect(0, 0, 1, 3), image.Rect(0, 0, 2, 2), image.Rect(0, 0, 3, 1), image.Rect(0, 0, 4, 4), }, Expected: []image.Rectangle{ image.Rect(0, 0, 4, 4), }, }, { NewRegions: []image.Rectangle{ image.Rect(0, 0, 1, 3), image.Rect(0, 0, 2, 2), image.Rect(0, 0, 3, 1), image.Rect(0, 0, 4, 4), image.Rect(1, 1, 2, 2), }, Expected: []image.Rectangle{ image.Rect(0, 0, 4, 4), }, }, { NewRegions: []image.Rectangle{ image.Rect(0, 0, 1, 3), image.Rect(0, 0, 2, 2), image.Rect(0, 0, 3, 1), image.Rect(0, 0, 4, 4), image.Rect(0, 0, 5, 5), }, Expected: []image.Rectangle{ image.Rect(0, 0, 5, 5), }, }, { Regions: []image.Rectangle{ image.Rect(0, 0, 1, 3), image.Rect(0, 0, 2, 2), image.Rect(0, 0, 3, 1), image.Rect(0, 0, 4, 4), }, NewRegions: []image.Rectangle{ image.Rect(0, 0, 5, 5), }, Expected: []image.Rectangle{ image.Rect(0, 0, 5, 5), }, }, { Regions: []image.Rectangle{ image.Rect(0, 0, 2, 2), image.Rect(0, 0, 3, 1), image.Rect(0, 0, 4, 4), image.Rect(0, 0, 5, 5), }, NewRegions: []image.Rectangle{ image.Rect(0, 0, 1, 3), }, Expected: []image.Rectangle{ image.Rect(0, 0, 2, 2), image.Rect(0, 0, 3, 1), image.Rect(0, 0, 4, 4), image.Rect(0, 0, 5, 5), }, }, } for _, c := range cases { got := c.Regions for _, r := range c.NewRegions { restorable.AppendRegionRemovingDuplicates(&got, r) } want := c.Expected if !areEqualRectangles(got, want) { t.Errorf("restorable.RemoveDuplicatedRegions(%#v): got: %#v, want: %#v", c.NewRegions, got, want) } } }