aboutsummaryrefslogtreecommitdiff
path: root/test/net/sourceforge/opentracking/protocol/xexun/XexunProtocolDecoderTest.java
blob: efbd020ed2193fc7d64ace94949f49e3603e2935 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package net.sourceforge.opentracking.protocol.xexun;

import java.util.Date;
import java.util.GregorianCalendar;
import java.util.List;
import org.junit.Test;
import net.sourceforge.opentracking.Device;
import net.sourceforge.opentracking.Position;
import net.sourceforge.opentracking.DataManager;
import static org.junit.Assert.*;

public class XexunProtocolDecoderTest {

    private class TestDataManager implements DataManager {
        public List getDevices() {
            return null;
        }

        public Device getDeviceByImei(String imei) {
            Device device = new Device();
            device.setId(new Long(1));
            device.setImei("10000000000000");
            return device;
        }

        public void setPosition(Position position) {
        }
    }

    @Test
    public void testDecode() throws Exception {

        String testMsg =
                "GPRMC,010203.000,A,0102.0003,N,00102.0003,E,1.02,1.02,010203,,,A*00,F,, " +
                "imei:10000000000000,";
                //"GPRMC,233842.000,A,5001.3060,N,01429.3243,E,0.00,,210211,,,A*74,F," +
                //"imei:354776030495631,";
                //1103100803,+79629503178,
                //"GPRMC,080303.000,A,5546.7313,N,03738.6005,E,0.56,160.13,100311,,,A*6A,L," +
                //"imei:354778030461167,";

        XexunProtocolDecoder decoder = new XexunProtocolDecoder(new TestDataManager());
        Position position = (Position) decoder.decode(null, null, testMsg);

        Date time = new GregorianCalendar(2003, 1, 1, 1, 2, 3).getTime();
        assertEquals(time, position.getTime());

        assertEquals(true, position.getValid());

        Double latitude = 1.0 + 2.0003 / 60.0;
        assertEquals(latitude, position.getLatitude());

        Double longitude = 1.0 + 2.0003 / 60.0;
        assertEquals(longitude, position.getLongitude());

        Double speed = 1.02;
        assertEquals(speed, position.getSpeed());

        Double course = 1.02;
        assertEquals(course, position.getCourse());
        
        Long deviceId = new Long(1);
        assertEquals(deviceId, position.getDeviceId());
    }

}