package cgeo.geocaching.location; import android.annotation.SuppressLint; import junit.framework.TestCase; import android.support.annotation.NonNull; import java.util.HashSet; import java.util.Locale; import java.util.Set; import cgeo.geocaching.models.ICoordinates; import static cgeo.geocaching.location.Viewport.containing; import static java.util.Collections.singleton; import static org.assertj.core.api.Java6Assertions.assertThat; public class ViewportTest extends TestCase { @NonNull private static final Viewport vpRef = new Viewport(new Geopoint(-1.0, -2.0), new Geopoint(3.0, 4.0)); public static void assertBounds(final Viewport vp) { assertThat(vp.center).isEqualTo(new Geopoint(1.0, 1.0)); assertThat(vp.topRight).isEqualTo(new Geopoint(3.0, 4.0)); assertThat(vp.bottomLeft).isEqualTo(new Geopoint(-1.0, -2.0)); } public static void testCreationBounds() { assertBounds(new Viewport(new Geopoint(-1.0, -2.0), new Geopoint(3.0, 4.0))); assertBounds(new Viewport(new Geopoint(3.0, 4.0), new Geopoint(-1.0, -2.0))); assertBounds(new Viewport(new Geopoint(-1.0, 4.0), new Geopoint(3.0, -2.0))); assertBounds(new Viewport(new Geopoint(3.0, -2.0), new Geopoint(-1.0, 4.0))); } public static void testCreationCenter() { assertBounds(new Viewport(new Geopoint(1.0, 1.0), 4.0, 6.0)); } public static void testCreationSeparate() { assertBounds(vpRef); } public static void testMinMax() { assertThat(vpRef.getLatitudeMin()).isEqualTo(-1.0); assertThat(vpRef.getLatitudeMax()).isEqualTo(3.0); assertThat(vpRef.getLongitudeMin()).isEqualTo(-2.0); assertThat(vpRef.getLongitudeMax()).isEqualTo(4.0); } public static void testSpans() { assertThat(vpRef.getLatitudeSpan()).isEqualTo(4.0); assertThat(vpRef.getLongitudeSpan()).isEqualTo(6.0); } public static void testInViewport() { assertThat(vpRef.contains(new Geopoint(-2.0, -2.0))).isFalse(); assertThat(vpRef.contains(new Geopoint(4.0, 4.0))).isFalse(); assertThat(vpRef.contains(Geopoint.ZERO)).isTrue(); assertThat(vpRef.contains(new Geopoint(-1.0, -2.0))).isTrue(); assertThat(vpRef.contains(new Geopoint(3.0, 4.0))).isTrue(); } @SuppressLint("DefaultLocale") public static void testSqlWhere() { assertThat(vpRef.sqlWhere(null).toString()).isEqualTo("latitude >= -1.0 and latitude <= 3.0 and longitude >= -2.0 and longitude <= 4.0"); assertThat(vpRef.sqlWhere("t").toString()).isEqualTo("t.latitude >= -1.0 and t.latitude <= 3.0 and t.longitude >= -2.0 and t.longitude <= 4.0"); Locale current = null; try { current = Locale.getDefault(); Locale.setDefault(Locale.FRENCH); assertThat(String.format("%.2g", 1.0d)).isEqualTo("1,0"); // Control that we are in a locale with comma separator assertThat(vpRef.sqlWhere("t").toString()).isEqualTo("t.latitude >= -1.0 and t.latitude <= 3.0 and t.longitude >= -2.0 and t.longitude <= 4.0"); } finally { Locale.setDefault(current); } } public static void testEquals() { assertThat(vpRef).isEqualTo(vpRef); assertThat(new Viewport(vpRef.bottomLeft, vpRef.topRight)).isEqualTo(vpRef); assertThat(vpRef.equals(new Viewport(new Geopoint(0.0, 0.0), 1.0, 1.0))).isFalse(); } public static void testResize() { assertThat(vpRef.resize(1.0)).isEqualTo(vpRef); assertThat(vpRef.resize(2.0)).isEqualTo(new Viewport(new Geopoint(-3.0, -5.0), new Geopoint(5.0, 7.0))); assertThat(vpRef.resize(0.5)).isEqualTo(new Viewport(new Geopoint(0.0, -0.5), new Geopoint(2.0, 2.5))); } public static void testIncludes() { assertThat(vpRef.includes(vpRef)).isTrue(); assertThat(vpRef.includes(vpRef.resize(0.5))).isTrue(); assertThat(vpRef.includes(vpRef.resize(2.0))).isFalse(); } public static void testContaining() { assertThat(containing(singleton((ICoordinates) null))).isNull(); final Set<Geopoint> points = new HashSet<>(); points.add(vpRef.bottomLeft); assertThat(containing(points)).isEqualTo(new Viewport(vpRef.bottomLeft, vpRef.bottomLeft)); points.add(vpRef.topRight); assertThat(containing(points)).isEqualTo(vpRef); points.add(vpRef.center); assertThat(containing(points)).isEqualTo(vpRef); } }