Files
poky/bitbake/bin/bitbake-hashserv
Richard Purdie ca04aaf7b5 bitbake: cooker/hashserv: Allow autostarting of a local hash server using BB_HASHSERVE
Its useful, particularly in the local developer model of usage, for
bitbake to start and stop a hash equivalence server on local port,
rather than relying on one being started by the user before the build.

The new BB_HASHSERVE variable supports this.

The database handling is moved internally into the hashserv code so that
different threads/processes can be used for the server without errors.

(Bitbake rev: a4fa8f1bd88995ae60e10430316fbed63d478587)

Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2019-08-06 11:21:31 +01:00

1.6 KiB
Executable File

#! /usr/bin/env python3

Copyright (C) 2018 Garmin Ltd.

SPDX-License-Identifier: GPL-2.0-only

import os import sys import logging import argparse import sqlite3

sys.path.insert(0, os.path.join(os.path.dirname(os.path.dirname(file)),'lib'))

import hashserv

VERSION = "1.0.0"

DEFAULT_HOST = '' DEFAULT_PORT = 8686

def main(): parser = argparse.ArgumentParser(description='HTTP Equivalence Reference Server. Version=%s' % VERSION) parser.add_argument('--address', default=DEFAULT_HOST, help='Bind address (default "%(default)s")') parser.add_argument('--port', type=int, default=DEFAULT_PORT, help='Bind port (default %(default)d)') parser.add_argument('--prefix', default='', help='HTTP path prefix (default "%(default)s")') parser.add_argument('--database', default='./hashserv.db', help='Database file (default "%(default)s")') parser.add_argument('--log', default='WARNING', help='Set logging level')

args = parser.parse_args()

logger = logging.getLogger('hashserv')

level = getattr(logging, args.log.upper(), None)
if not isinstance(level, int):
    raise ValueError('Invalid log level: %s' % args.log)

logger.setLevel(level)
console = logging.StreamHandler()
console.setLevel(level)
logger.addHandler(console)

server = hashserv.create_server((args.address, args.port), args.database, args.prefix)
server.serve_forever()
return 0

if name == 'main': try: ret = main() except Exception: ret = 1 import traceback traceback.print_exc() sys.exit(ret)