mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
Runs on default spec: 2-core CPU (x86_64) 7 GB of RAM 14 GB of SSD space https://docs.github.com/en/actions/using-github-hosted-runners/about-github-hosted-runners#supported-runners-and-hardware-resources Signed-off-by: Rohit Yadav <rohit.yadav@shapeblue.com>
112 lines
3.1 KiB
Python
Executable File
112 lines
3.1 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
# Licensed to the Apache Software Foundation (ASF) under one
|
|
# or more contributor license agreements. See the NOTICE file
|
|
# distributed with this work for additional information
|
|
# regarding copyright ownership. The ASF licenses this file
|
|
# to you under the Apache License, Version 2.0 (the
|
|
# "License"); you may not use this file except in compliance
|
|
# with the License. You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing,
|
|
# software distributed under the License is distributed on an
|
|
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
# KIND, either express or implied. See the License for the
|
|
# specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
"""
|
|
This script provides parsing of xunit xml files.
|
|
|
|
"""
|
|
|
|
import os
|
|
import argparse
|
|
|
|
import texttable
|
|
|
|
import lxml.etree
|
|
|
|
|
|
def main():
|
|
"""
|
|
Entry point for the parser
|
|
|
|
"""
|
|
|
|
args = _generate_args()
|
|
file_path_list = _generate_file_list(args)
|
|
|
|
exit(parse_reports(file_path_list))
|
|
|
|
|
|
def _generate_args():
|
|
parser = argparse.ArgumentParser(
|
|
description='Command line utility for reading xunit xml files'
|
|
)
|
|
|
|
parser.add_argument(
|
|
'path',
|
|
metavar='/path/to/folder/containing/xunit-reports',
|
|
type=str,
|
|
help='A path to a folder containing xunit reports'
|
|
)
|
|
|
|
args = parser.parse_args()
|
|
|
|
return vars(args)
|
|
|
|
|
|
def _generate_file_list(args):
|
|
path = args.pop('path')
|
|
file_path_list = []
|
|
if path.endswith('.xml') and os.path.isfile(path):
|
|
file_path_list.append(path)
|
|
for (root, dirnames, filenames) in os.walk(path):
|
|
for filename in filenames:
|
|
if filename.endswith('.xml'):
|
|
file_path_list.append(os.path.join(root, filename))
|
|
|
|
return file_path_list
|
|
|
|
|
|
def parse_reports(file_path_list):
|
|
table = texttable.Texttable()
|
|
table.header(['Test', 'Result', 'Time', 'Test file'])
|
|
|
|
exit_code = 0
|
|
|
|
for file_path in file_path_list:
|
|
data = lxml.etree.iterparse(file_path, tag='testcase', huge_tree=True)
|
|
for event, elem in data:
|
|
name = ''
|
|
status = 'Success'
|
|
time = ''
|
|
if 'name' in elem.attrib:
|
|
name = elem.attrib['name']
|
|
if 'time' in elem.attrib:
|
|
time = elem.attrib['time']
|
|
for children in elem.getchildren():
|
|
if 'skipped' == children.tag:
|
|
status = 'Skipped'
|
|
elif 'failure' == children.tag:
|
|
exit_code = 1
|
|
status = 'Failure'
|
|
elif 'error' == children.tag:
|
|
exit_code = 1
|
|
status = 'Error'
|
|
if 'type' in children.attrib:
|
|
status = children.attrib['type']
|
|
|
|
if status not in ('Skipped', 'Success'):
|
|
table.add_row([name, status, time, file_path.replace(".xml", "").split("/")[-1]])
|
|
|
|
print(table.draw())
|
|
|
|
return exit_code
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|