summaryrefslogtreecommitdiffstats
path: root/legacy/utils/dashboard/pushtoDB.py
blob: 427d39c4203820f7ad87b1a0e278c2659ada66eb (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
67
68
69
70
71
72
73
74
import requests
import json
import datetime
import os
import sys
from qtip.utils import logger_utils

logger = logger_utils.QtipLogger('push_db').get

TEST_DB = 'http://testresults.opnfv.org/test/api/v1'

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, installer, pod_name):

    url = db_url + "/results"
    creation_date = str(datetime.datetime.utcnow().isoformat())

    params = {"project_name": "qtip", "case_name": case_name,
              "pod_name": pod_name, "installer": installer, "start_date": creation_date,
              "version": "test", "details": payload}

    headers = {'Content-Type': 'application/json'}
    logger.info('pod_name:{0},installer:{1},creation_data:{2}'.format(pod_name,
                                                                      installer,
                                                                      creation_date))
    # temporary code, will be deleted after Bigergia dashboard is ready
    try:
        qtip_testapi_url = "http://testapi.qtip.openzero.net/results"
        qtip_testapi_r = requests.post(qtip_testapi_url, data=json.dumps(params), headers=headers)
        logger.info('Pushing Results to qtip_testapi: %s'.format(qtip_testapi_r))
    except:
        logger.info("Pushing Results to qtip_testapi Error:{0}".format(sys.exc_info()[0]))

    try:
        r = requests.post(url, data=json.dumps(params), headers=headers)
        logger.info(r)
        return True
    except:
        logger.info("Error:{0}".format(sys.exc_info()[0]))
        return False


def populate_payload(suite_list):

    global payload_list
    for k, v in suite_list:

        if os.path.isfile('results/' + str(k)):
            payload_list[k] = v


def main():

    global payload_list
    populate_payload(suite_list)
    if payload_list:
        logger.info(payload_list)
        for suite, case in payload_list.items():
            with open('results/' + suite, 'r') as result_file:
                j = json.load(result_file)
            push_results_to_db(TEST_DB, case, j,
                               os.environ['INSTALLER_TYPE'],
                               os.environ['NODE_NAME'])
    elif not payload_list:
        logger.info('Results not found')


if __name__ == "__main__":
    main()