aboutsummaryrefslogtreecommitdiff
path: root/log_raider/cli/jenkins.py
blob: 27094fbe6b0f89323e8821572300928acb8b4ff9 (plain) (blame)
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
import argparse
import json
import os
import sys

from .. import jenkins
from .. import __version__


def main():
    parser = argparse.ArgumentParser()
    parser.add_argument("-j", "--json", action="store_true", help="Emit JSON")
    parser.add_argument("-v", "--verbose", action="store_true", help="Increase verbosity")
    parser.add_argument("-V", "--version", action="store_true", help="Show version")
    parser.add_argument("logfile", nargs='?', help="Path to Jenkins log file")

    args = parser.parse_args()

    if args.version:
        print(__version__)
        exit(0)

    if not args.logfile:
        print(f"{os.path.basename(sys.argv[0])}: error: the following arguments are required: logfile")
        parser.print_help()
        exit(1)

    if not os.path.exists(args.logfile):
        print(f"{args.logfile}: does not exist")

    if args.verbose:
        jenkins.verbose_enable()

    data = jenkins.parse_log(args.logfile)

    if args.json:
        print(json.dumps(data, indent=2))
    else:
        for x in data:
            print("#" * 79)
            print(f"{x['type']} - {x['name']} (line @ {x['line']})")
            print("#" * 79)
            print(f"{x['data']}")


if __name__ == "__main__":
    sys.exit(main())