Factor out sub args from traffic script

This commit is contained in:
nolash 2021-02-21 11:00:17 +01:00
parent 2b535e2f31
commit 1727f75be8
Signed by untrusted user who does not match committer: lash
GPG Key ID: 21D2E7BB88C2A746
2 changed files with 15 additions and 16 deletions

View File

@ -5,6 +5,7 @@ import uuid
import importlib import importlib
import random import random
import copy import copy
from argparse import RawTextHelpFormatter
# external imports # external imports
import redis import redis
@ -13,6 +14,17 @@ from cic_eth.api.api_task import Api
logg = logging.getLogger(__name__) logg = logging.getLogger(__name__)
def add_args(argparser):
argparser.formatter_class = formatter_class=RawTextHelpFormatter
argparser.add_argument('--redis-host-callback', dest='redis_host_callback', default='localhost', type=str, help='redis host to use for callback')
argparser.add_argument('--redis-port-callback', dest='redis_port_callback', default=6379, type=int, help='redis port to use for callback')
argparser.add_argument('--batch-size', dest='batch_size', default=10, type=int, help='number of events to process simultaneously')
argparser.description = """Generates traffic on the cic network using dynamically loaded modules as event sources
"""
return argparser
class TrafficItem: class TrafficItem:
def __init__(self, item): def __init__(self, item):

View File

@ -4,7 +4,6 @@ import logging
import re import re
import sys import sys
import json import json
from argparse import RawTextHelpFormatter
# external imports # external imports
import redis import redis
@ -25,23 +24,14 @@ from cmd.traffic import (
TrafficProvisioner, TrafficProvisioner,
TrafficSyncHandler, TrafficSyncHandler,
) )
from cmd.traffic import add_args as add_traffic_args
# common basics
script_dir = os.path.realpath(os.path.dirname(__file__)) script_dir = os.path.realpath(os.path.dirname(__file__))
logg = common.log.create() logg = common.log.create()
argparser = common.argparse.create(script_dir, common.argparse.full_template) argparser = common.argparse.create(script_dir, common.argparse.full_template)
argparser = common.argparse.add(argparser, add_traffic_args, 'traffic')
def subprocessor(subparser):
subparser.formatter_class = formatter_class=RawTextHelpFormatter
subparser.add_argument('--redis-host-callback', dest='redis_host_callback', default='localhost', type=str, help='redis host to use for callback')
subparser.add_argument('--redis-port-callback', dest='redis_port_callback', default=6379, type=int, help='redis port to use for callback')
subparser.add_argument('--batch-size', dest='batch_size', default=10, type=int, help='number of events to process simultaneously')
subparser.description = """Generates traffic on the cic network using dynamically loaded modules as event sources
"""
argparser = common.argparse.add(argparser, subprocessor, 'traffic')
args = common.argparse.parse(argparser, logg) args = common.argparse.parse(argparser, logg)
config = common.config.create(args.c, args, args.env_prefix) config = common.config.create(args.c, args, args.env_prefix)
@ -52,14 +42,11 @@ if batchsize < 1:
logg.info('batch size {}'.format(batchsize)) logg.info('batch size {}'.format(batchsize))
config.add(batchsize, '_BATCH_SIZE', True) config.add(batchsize, '_BATCH_SIZE', True)
# redis task result callback
config.add(args.redis_host_callback, '_REDIS_HOST_CALLBACK', True) config.add(args.redis_host_callback, '_REDIS_HOST_CALLBACK', True)
config.add(args.redis_port_callback, '_REDIS_PORT_CALLBACK', True) config.add(args.redis_port_callback, '_REDIS_PORT_CALLBACK', True)
# keystore
config.add(args.y, '_KEYSTORE_FILE', True) config.add(args.y, '_KEYSTORE_FILE', True)
# queue
config.add(args.q, '_CELERY_QUEUE', True) config.add(args.q, '_CELERY_QUEUE', True)
common.config.log(config) common.config.log(config)