diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2015-08-07 16:04:50 +1200 |
---|---|---|
committer | Anton Tananaev <anton.tananaev@gmail.com> | 2015-08-07 16:04:50 +1200 |
commit | 6bf34cb1235d98acfb230c9d07c8b280ef7c9544 (patch) | |
tree | bc6d36c7fac956799901936dd3d9822c6c04bb1f /tools/test-integration.py | |
parent | 74f54436bc43b9d2ed9d3d06760c7aaae9464b4b (diff) | |
download | trackermap-server-6bf34cb1235d98acfb230c9d07c8b280ef7c9544.tar.gz trackermap-server-6bf34cb1235d98acfb230c9d07c8b280ef7c9544.tar.bz2 trackermap-server-6bf34cb1235d98acfb230c9d07c8b280ef7c9544.zip |
Add integration testing script
Diffstat (limited to 'tools/test-integration.py')
-rwxr-xr-x | tools/test-integration.py | 126 |
1 files changed, 126 insertions, 0 deletions
diff --git a/tools/test-integration.py b/tools/test-integration.py new file mode 100755 index 000000000..cfecd15c1 --- /dev/null +++ b/tools/test-integration.py @@ -0,0 +1,126 @@ +#!/usr/bin/python + +import os +import xml.etree.ElementTree +import urllib +import urllib2 +import json +import socket +import time + +messages = { + 'gps103' : 'imei:123456789012345,help me,1201011201,,F,120100.000,A,6000.0000,N,13000.0000,E,0.00,;', + 'tk103' : '(123456789012BP05123456789012345120101A6000.0000N13000.0000E000.0120200000.0000000000L000946BB)', + 'gl100' : '+RESP:GTSOS,123456789012345,0,0,0,1,0.0,0,0.0,1,130.000000,60.000000,20120101120300,0460,0000,18d8,6141,00,11F0,0102120204\0', + 'gl200' : '+RESP:GTFRI,020102,123456789012345,,0,0,1,1,0.0,0,0.0,130.000000,60.000000,20120101120400,0460,0000,18d8,6141,00,,20120101120400,11F0$', + 't55' : '$PGID,123456789012345*0F\r\n$GPRMC,120500.000,A,6000.0000,N,13000.0000,E,0.00,0.00,010112,,*33\r\n', + 'xexun' : '111111120009,+436763737552,GPRMC,120600.000,A,6000.0000,N,13000.0000,E,0.00,0.00,010112,,,A*68,F,, imei:123456789012345,04,481.2,F:4.15V,0,139,2689,232,03,2725,0576\n', + 'totem' : '$$B3123456789012345|AA$GPRMC,120700.000,A,6000.0000,N,13000.0000,E,0.00,,010112,,,A*74|01.8|01.0|01.5|000000000000|20120403234603|14251914|00000000|0012D888|0000|0.0000|3674|940B\r\n', + 'meiligao' : '$$\x00\x60\x12\x34\x56\xFF\xFF\xFF\xFF\x99\x55120900.000,A,6000.0000,N,13000.0000,E,0.00,,010112,,*1C|11.5|194|0000|0000,0000\x69\x62\x0D\x0A', + 'suntech' : 'SA200STT;123456;042;20120101;12:11:00;16d41;-15.618767;-056.083214;000.011;000.00;11;1;41557;12.21;000000;1;3205\r', + 'h02' : '*HQ,123456789012345,V1,121300,A,6000.0000,N,13000.0000,E,0.00,0.00,010112,ffffffff,000000,000000,000000,000000#', + 'jt600' : '$\x00\x00\x12\x34\x56\x11\x00\x1B\x01\x01\x12\x12\x14\x00\x60\x00\x00\x00\x13\x00\x00\x00\x0F\x00\x00\x07\x50\x00\x00\x00\x2B\x91\x04\x4D\x1F\xA1', + 'ev603' : '!1,123456789012345;!A,01/01/12,12:15:00,60.000000,130.000000,0.0,25101,0;', + 'v680' : '#123456789012345#1000#0#1000#AUT#1#66830FFB#13000.0000,E,6000.0000,N,001.41,259#010112#121600##', + 'pt502' : '$POS,123456,121700.000,A,6000.0000,N,13000.0000,E,0.0,0.0,010112,,,A/00000,00000/0/23895000//\r\n', + 'tr20' : '%%123456789012345,A,120101121800,N6000.0000E13000.0000,0,000,0,01034802,150,[Message]\r\n', + 'meitrack' : '$$d138,123456789012345,AAA,35,60.000000,130.000000,120101122000,A,7,18,0,0,0,49,3800,24965,510|10|0081|4F4F,0000,000D|0010|0012|0963|0000,,*BF\r\n', + 'megastek' : 'STX,102110830074542,$GPRMC,122400.000,A,6000.0000,N,13000.0000,E,0.00,0.00,010112,,,A*64,F,LowBattery,imei:123456789012345,03,113.1,Battery=24%,,1,460,01,2531,647E;57\r\n', + 'gpsgate' : '$FRLIN,IMEI,123456789012345,*7B\r\n$GPRMC,122600.000,A,6000.00000,N,13000.00000,E,0.000,0.0,010112,,*0A\r\n', + 'tlt2h' : '#123456789012345#V500#0000#AUTO#1\r\n#$GPRMC,123000.000,A,6000.0000,N,13000.0000,E,0.00,0.00,010112,,,D*70\r\n##', + 'taip' : '>REV481669045060+6000000-1300000000000012;ID=123456789012345<', + 'wondex' : '123456789012345,20120101123200,130.000000,60.000000,0,000,0,0,2\r\n', + 'ywt' : '%RP,123456789012345:0,120101123500,E130.000000,N60.000000,,0,0,4,0,00\r\n', + 'tk102' : '[!0000000081r(123456789012345,TK102-W998_01_V1.1.001_130219,255,001,255,001,0,100,100,0,internet,0000,0000,0,0,255,0,4,1,11,00)][=00000000836(ITV123600A6000.0000N13000.0000E000.00001011210010000)]', + 'intellitrac' : '123456789012345,20120101123700,130.000000,60.000000,0,0,0,7,0,11,15\r\n', + 'wialon' : '#L#123456789012345;test\r\n#SD#010112;123900;6000.0000;N;13000.0000;E;0;0;0;4\r\n', + 'carscop' : '*040331141830UB05123456789012345010112A6000.0000N13000.0000E000.0124000000.0000000000L000000^', + 'manpower' : 'simei:123456789012345,,,tracker,51,24,1.73,120101124200,A,6000.0000,N,13000.0000,E,0.00,28B9,1DED,425,01,1x0x0*0x1*60x+2,en-us,;', + 'globalsat' : '$123456789012345,1,1,010112,124300,E13000.0000,N6000.0000,00000,0.0100,147,07,2.4!', + 'pt3000' : '%123456789012345,$GPRMC,124500.000,A,6000.0000,N,13000.0000,E,0.00,,010112,,,A,+100000000000,N098d', + 'topflytech' : '(123456789012345BP00XG00b600000000L00074b54S00000000R0C0F0014000100f0120101124700A6000.0000N13000.0000E000.0000.00)', + 'laipac' : '$AVRMC,123456789012345,124800,a,6000.0000,N,13000.0000,E,0.00,0.00,010112,0,3.727,17,1,0,0*17\r\n', + 'gotop' : '#123456789012345,CMD-T,A,DATE:120101,TIME:125000,LAT:60.0000000N,LOT:130.0000000E,Speed:000.0,84-20,000#' +} + +baseUrl = 'http://localhost:8082' +user = { 'email' : 'admin', 'password' : 'admin' } + +def load_ports(): + ports = {} + dir = os.path.dirname(os.path.abspath(__file__)) + root = xml.etree.ElementTree.parse(dir + '/../debug.xml').getroot() + for entry in root.findall('entry'): + key = entry.attrib['key'] + if key.endswith('.port'): + ports[key[:-5]] = int(entry.text) + return ports + +def login(): + request = urllib2.Request(baseUrl + '/api/login') + response = urllib2.urlopen(request, urllib.urlencode(user)) + return response.headers.get('Set-Cookie') + +def remove_devices(cookie): + request = urllib2.Request(baseUrl + '/api/device/get') + request.add_header('cookie', cookie) + response = urllib2.urlopen(request) + data = json.load(response) + for device in data['data']: + request = urllib2.Request(baseUrl + '/api/device/remove') + request.add_header('cookie', cookie) + response = urllib2.urlopen(request, json.dumps(device)) + +def add_device(cookie, unique_id): + request = urllib2.Request(baseUrl + '/api/device/add') + request.add_header('cookie', cookie) + user = { 'name' : unique_id, 'uniqueId' : unique_id } + response = urllib2.urlopen(request, json.dumps(user)) + data = json.load(response) + return data['data']['id'] + +def send_message(port, message): + s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) + s.connect(('127.0.0.1', port)) + s.send(message) + s.close() + +def get_protocols(cookie, device_id): + request = urllib2.Request(baseUrl + '/api/position/get') + request.add_header('cookie', cookie) + params = { 'deviceId' : device_id, 'from' : '2000-01-01T00:00:00.000Z', 'to' : '2050-01-01T00:00:00.000Z' } + response = urllib2.urlopen(request, urllib.urlencode(params)) + protocols = [] + data = json.load(response) + for position in data['data']: + protocols.append(position['protocol']) + return protocols + +ports = load_ports() + +cookie = login() +remove_devices(cookie) + +devices = { + '123456789012345' : add_device(cookie, '123456789012345'), + '123456789012' : add_device(cookie, '123456789012'), + '123456' : add_device(cookie, '123456') +} + +print 'Total: %d' % len(messages) + +for protocol in messages: + send_message(ports[protocol], messages[protocol]) + +time.sleep(5) + +protocols = set(messages.keys()) + +for device in devices: + protocols -= set(get_protocols(cookie, devices[device])) + +print 'Success: %d' % (len(messages) - len(protocols)) +print 'Failed: %d' % len(protocols) + +if protocols: + print '\nFailed: %s' % repr(list(protocols)) |