summaryrefslogtreecommitdiffstats
path: root/dashboard/pushtoDB.py
blob: b889f21cc9d3ef1dc96c8a09d10abfee07b8a65b (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
import requests
import json
import datetime
import os
TEST_DB = 'http://213.77.62.197'

suite_list = [('compute_result.json', 'compute_test_suite'),('network_result.json', 'network_test_suite'),('storage_result.json', 'storage_test_suite')]
payload_list = { }

def push_results_to_db(db_url, case_name, payload,logger=None, pod_name="dell-us-testing-1"):

    url = db_url + "/results"
    creation_date= str(datetime.datetime.utcnow().isoformat())
    installer = os.environ['INSTALLER_TYPE']
    #pod_name = os.environ['NODE_NAME']
    print url
    print case_name
    print logger
    print pod_name
    
    params = {"project_name": "qtip", "case_name": case_name,
              "pod_name": pod_name, "installer": installer, "creation_date": creation_date,
              "version": "test" , "details": payload}

    headers = {'Content-Type': 'application/json'}
    print params
    
    try:
        r = requests.post(url, data=json.dumps(params), headers=headers)
        print r
        return True
    except:
        print "Error:", sys.exc_info()[0]
        return False
    
def populate_payload(suite_list):

    global payload_list
    for k,v in suite_list:
        print 'results/'+k
        if os.path.isfile('results/'+str(k)):
            payload_list[k]=v
    
    print payload_list

def main():

    global payload_list
    populate_payload(suite_list)
    for suite,case in payload_list.items():
        with open('results/'+suite,'r') as result_file:
            j=result_file.read().rstrip()
            
        push_results_to_db(TEST_DB, 'Compute benchmark suite',j)

if __name__ == "__main__":
    main()