blob: 026a46d16291ec577edb17fe2da43368ca724145 [file] [log] [blame]
from urlparse import urlparse
# from gspread import WorksheetNotFound, login
import json
import os
from gspread import login, WorksheetNotFound
from config import ROW_COUNT, DOCUMENT_ID, WORK_SHEET
TEST_PATH = os.environ.get("TEST_PATH", os.path.dirname(__file__) + "/test_results")
def get_work_sheet(sheet, name, column_names):
try:
work_sheet = sheet.worksheet(name)
except WorksheetNotFound:
work_sheet = sheet.add_worksheet(title=name, rows=ROW_COUNT,
cols=max(40, len(column_names)))
for i in range(1, len(column_names) + 1):
work_sheet.update_cell(1, i, column_names[i - 1])
return work_sheet
def get_row_number(work_sheet):
num = 2
while num < work_sheet.row_count and work_sheet.cell(num, 1).value != "":
num += 1
if num == work_sheet.row_count:
work_sheet.append_row(["" for x in range(work_sheet.col_count)])
return num
def append_row(work_sheet, row):
row_number = get_row_number(work_sheet)
i = 1
for k in row.keys():
work_sheet.update_cell(row_number, i, row[k])
i += 1
class Measurement(object):
def __init__(self):
self.build = ""
self.build_type = 0 # GA/Master/Other
self.md5 = ""
self.results = {
"": (float, float)
}
def __str__(self):
return self.build + " " + self.build_type + " " + \
self.md5 + " " + str(self.results)
def create_storage(url, email=None, password=None):
u = urlparse(url)
if u.scheme == 'file':
storage = DiskStorage(u.path)
else:
storage = GoogleDocsStorage(DOCUMENT_ID, WORK_SHEET, email, password)
return storage
class Storage(object):
def store(self, data):
pass
def retrieve(self, id):
pass
class GoogleDocsStorage(Storage):
def __init__(self, doc_id, work_sheet_name, email=None, password=None):
self.gc = login(email, password)
self.sh = self.gc.open_by_key(doc_id)
self.work_sheet = get_work_sheet(self.sh, work_sheet_name, 40)
def store(self, data):
append_row(self.work_sheet, data)
def retrieve(self, id):
row_number = self.find_by_id(id)
if row_number != -1:
vals = self.work_sheet.row_values(row_number)
m = Measurement()
m.build = vals.pop("build_id")
m.build_type = vals.pop("type")
m.md5 = vals.pop("iso_md5")
m.results = {k: vals[k] for k in vals.keys()}
else:
return None
def find_by_id(self, row_id):
for i in range(1, self.work_sheet):
if self.work_sheet.cell(i, 1) == row_id:
return i
return -1
def recent_builds(self):
i = self.work_sheet.row_count - 1
d = {}
result = []
while i > 0:
vals = self.work_sheet.row_values(i)
if vals["type"] not in d:
d[vals["type"]] = vals
m = Measurement()
m.build = vals.pop("build_id")
m.build_type = vals.pop("type")
m.md5 = vals.pop("iso_md5")
m.results = {k: vals[k] for k in vals.keys()}
result.append(m)
i -= 1
return result
class DiskStorage(Storage):
def __init__(self, file_name):
self.file_name = file_name
if not os.path.exists(file_name):
with open(file_name, "w+") as f:
f.write(json.dumps([]))
def store(self, data):
with open(self.file_name, "rt") as f:
raw_data = f.read()
document = json.loads(raw_data)
document.append(data)
with open(self.file_name, "w+") as f:
f.write(json.dumps(document))
def retrieve(self, id):
with open(self.file_name, "rt") as f:
raw_data = f.read()
document = json.loads(raw_data)
for row in document:
if row["build_id"] == id:
m = Measurement()
m.build = row.pop("build_id")
m.build_type = row.pop("type")
m.md5 = row.pop("iso_md5")
m.results = {k.split(" "): row[k] for k in row.keys()}
return m
return None
def recent_builds(self):
with open(self.file_name, "rt") as f:
raw_data = f.read()
document = json.loads(raw_data)
d = {}
result = {}
build_types = {"GA", "master"}
for i in range(len(document) - 1, -1, - 1):
if document[i]["type"] in build_types:
if document[i]["type"] not in d:
d[document[i]["type"]] = document[i]
elif "other" not in d:
d["other"] = document[i]
for k in d.keys():
m = Measurement()
m.build = d[k].pop("build_id")
m.build_type = d[k].pop("type")
m.md5 = d[k].pop("iso_md5")
m.results = {k: v for k, v in d[k].items()}
result[m.build_type] = m
return result
if __name__ == "__main__":
storage = create_storage("file:///home/gstepanov/rally-results-processor/sample.json", "", "")
print storage.recent_builds()