/* * Copyright 2007 ZXing 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 ntu.com.google.zxing.client.result; import ntu.com.google.zxing.BarcodeFormat; import ntu.com.google.zxing.Result; import org.junit.Assert; import org.junit.Test; /** * Tests {@link ntu.com.google.zxing.client.result.GeoParsedResult}. * * @author Sean Owen */ public final class GeoParsedResultTestCase extends Assert { private static final double EPSILON = 0.0000000001; @Test public void testGeo() { doTest("geo:1,2", 1.0, 2.0, 0.0, null); doTest("geo:80.33,-32.3344,3.35", 80.33, -32.3344, 3.35, null); doTest("geo:-20.33,132.3344,0.01", -20.33, 132.3344, 0.01, null); doTest("geo:-20.33,132.3344,0.01?q=foobar", -20.33, 132.3344, 0.01, "q=foobar"); } private static void doTest(String contents, double latitude, double longitude, double altitude, String query) { Result fakeResult = new Result(contents, null, null, BarcodeFormat.QR_CODE); ParsedResult result = ResultParser.parseResult(fakeResult); assertSame(ParsedResultType.GEO, result.getType()); GeoParsedResult geoResult = (GeoParsedResult) result; assertEquals(latitude, geoResult.getLatitude(), EPSILON); assertEquals(longitude, geoResult.getLongitude(), EPSILON); assertEquals(altitude, geoResult.getAltitude(), EPSILON); assertEquals(query, geoResult.getQuery()); } }