Merge "Support verbose showconfig in tox siblings"

This commit is contained in:
Zuul 2021-09-30 15:51:41 +00:00 committed by Gerrit Code Review
commit e6cabd2f69

View File

@ -52,6 +52,12 @@ try:
except ImportError: except ImportError:
import ConfigParser as configparser import ConfigParser as configparser
# Workaround for lack of configparser.read_string() on Python 2.7
try:
from io import StringIO
except ImportError:
from StringIO import StringIO
import os import os
import ast import ast
import subprocess import subprocess
@ -265,7 +271,13 @@ def install_siblings(envdir, projects, package_name, constraints):
def get_envlist(tox_config): def get_envlist(tox_config):
envlist = [] envlist = []
if 'tox' in tox_config.sections(): # This is overly LBYL to deal with differences in older Python 2.7
# ConfigParser which would necessitate a fairly large number of exceptions
# if we wanted to do a simple try/except with the get() instead
if (
'tox' in tox_config.sections() and 'env' in
tox_config.options('tox') and "'-e" not in
tox_config.get('tox', 'args')):
envlist_default = ast.literal_eval( envlist_default = ast.literal_eval(
tox_config.get('tox', 'envlist_default')) tox_config.get('tox', 'envlist_default'))
tox_args = ast.literal_eval(tox_config.get('tox', 'args')) tox_args = ast.literal_eval(tox_config.get('tox', 'args'))
@ -278,6 +290,7 @@ def get_envlist(tox_config):
envlist.append(testenv) envlist.append(testenv)
else: else:
for section in tox_config.sections(): for section in tox_config.sections():
if section.startswith('testenv:'):
envlist.append(section.split(':')[1]) envlist.append(section.split(':')[1])
return envlist return envlist
@ -298,8 +311,25 @@ def main():
projects = module.params['projects'] projects = module.params['projects']
tox_show_config = module.params.get('tox_show_config') tox_show_config = module.params.get('tox_show_config')
# Filter out any leading verbose output lines before the config
with open(tox_show_config) as tox_raw_config:
tox_clean_config = ''
discard = True
for line in tox_raw_config:
if not discard:
# Normal operation, tested first for efficiency
tox_clean_config += line
elif line.startswith('['):
# Once we see a section heading, stop discarding
discard = False
tox_clean_config += line
tox_config = configparser.RawConfigParser() tox_config = configparser.RawConfigParser()
tox_config.read(tox_show_config) # Workaround for lack of configparser.read_string() on Python 2.7
try:
tox_config.read_string(tox_clean_config)
except AttributeError:
tox_config.readfp(StringIO(unicode(tox_clean_config))) # noqa: F821
envlist = get_envlist(tox_config) envlist = get_envlist(tox_config)