mirror of
https://github.com/pyTooling/Actions.git
synced 2026-02-12 02:56:56 +08:00
includes and excludes.
This commit is contained in:
72
.github/workflows/Parameters.yml
vendored
72
.github/workflows/Parameters.yml
vendored
@@ -25,6 +25,10 @@ name: Parameters
|
|||||||
on:
|
on:
|
||||||
workflow_call:
|
workflow_call:
|
||||||
inputs:
|
inputs:
|
||||||
|
name:
|
||||||
|
description: 'Name of the tool.'
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
python_version:
|
python_version:
|
||||||
description: 'Python version.'
|
description: 'Python version.'
|
||||||
required: false
|
required: false
|
||||||
@@ -33,16 +37,22 @@ on:
|
|||||||
python_version_list:
|
python_version_list:
|
||||||
description: 'Space separated list of Python versions to run tests with.'
|
description: 'Space separated list of Python versions to run tests with.'
|
||||||
required: false
|
required: false
|
||||||
default: '3.7 3.8 3.9 3.10 3.11 pypy-3.7 pypy-3.8 pypy-3.9'
|
default: '3.7 3.8 3.9 3.10 3.11'
|
||||||
type: string
|
type: string
|
||||||
system_list:
|
system_list:
|
||||||
description: 'Space separated list of systems to run tests on.'
|
description: 'Space separated list of systems to run tests on.'
|
||||||
required: false
|
required: false
|
||||||
default: 'ubuntu windows mingw64 macos'
|
default: 'ubuntu windows mingw64 macos'
|
||||||
type: string
|
type: string
|
||||||
name:
|
include_list:
|
||||||
description: 'Name of the tool.'
|
description: 'Space separated list of system:python items to be included into the list of test.'
|
||||||
required: true
|
required: false
|
||||||
|
default: ''
|
||||||
|
type: string
|
||||||
|
exclude_list:
|
||||||
|
description: 'Space separated list of system:python items to be excluded from the list of test.'
|
||||||
|
required: false
|
||||||
|
default: ''
|
||||||
type: string
|
type: string
|
||||||
outputs:
|
outputs:
|
||||||
params:
|
params:
|
||||||
@@ -66,11 +76,14 @@ jobs:
|
|||||||
shell: python
|
shell: python
|
||||||
run: |
|
run: |
|
||||||
from pprint import pprint
|
from pprint import pprint
|
||||||
|
from textwrap import dedent
|
||||||
|
|
||||||
name = "${{ inputs.name }}".strip()
|
name = "${{ inputs.name }}".strip()
|
||||||
pythonVersion = "${{ inputs.python_version }}".strip()
|
pythonVersion = "${{ inputs.python_version }}".strip()
|
||||||
systems = "${{ inputs.system_list }}".strip()
|
systems = "${{ inputs.system_list }}".strip()
|
||||||
versions = "${{ inputs.python_version_list }}".strip()
|
versions = "${{ inputs.python_version_list }}".strip()
|
||||||
|
include_list = "${{ inputs.include_list }}".strip()
|
||||||
|
exclude_list = "${{ inputs.exclude_list }}".strip()
|
||||||
|
|
||||||
currentMSYS2Version = "3.10"
|
currentMSYS2Version = "3.10"
|
||||||
currentAlphaVersion = "3.12"
|
currentAlphaVersion = "3.12"
|
||||||
@@ -100,6 +113,16 @@ jobs:
|
|||||||
else:
|
else:
|
||||||
versions = [ver.strip() for ver in versions.split(" ")]
|
versions = [ver.strip() for ver in versions.split(" ")]
|
||||||
|
|
||||||
|
if include_list == "":
|
||||||
|
includes = []
|
||||||
|
else:
|
||||||
|
includes = [tuple(include.strip().split(":")) for include in include_list.split(" ")]
|
||||||
|
|
||||||
|
if exclude_list == "":
|
||||||
|
excludes = []
|
||||||
|
else:
|
||||||
|
excludes = [exclude.strip() for exclude in exclude_list.split(" ")]
|
||||||
|
|
||||||
if "3.6" in versions:
|
if "3.6" in versions:
|
||||||
print("::warning title=Deprecated::Support for Python 3.6 ended in 2021.12.23.")
|
print("::warning title=Deprecated::Support for Python 3.6 ended in 2021.12.23.")
|
||||||
if "msys2" in systems:
|
if "msys2" in systems:
|
||||||
@@ -138,6 +161,29 @@ jobs:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
print("includes:")
|
||||||
|
for system,version in includes:
|
||||||
|
print(f"- {system}:{version}")
|
||||||
|
print("excludes:")
|
||||||
|
for exclude in excludes:
|
||||||
|
print(f"- {exclude}")
|
||||||
|
|
||||||
|
combinations = [
|
||||||
|
(system, version)
|
||||||
|
for system in systems
|
||||||
|
if system in data['sys'] or system in data['runtime']
|
||||||
|
for version in versions
|
||||||
|
if version in data['python']
|
||||||
|
and f"{system}:{version}" not in excludes
|
||||||
|
] + [
|
||||||
|
(system, version)
|
||||||
|
for system, version in includes
|
||||||
|
if system in data['sys']
|
||||||
|
and version in data['python']
|
||||||
|
]
|
||||||
|
#print("combinations:")
|
||||||
|
#print(combinations)
|
||||||
|
|
||||||
jobs = [
|
jobs = [
|
||||||
{
|
{
|
||||||
'sysicon': data['sys'][system]['icon'],
|
'sysicon': data['sys'][system]['icon'],
|
||||||
@@ -148,8 +194,7 @@ jobs:
|
|||||||
'python': currentAlphaRelease if version == currentAlphaVersion else version,
|
'python': currentAlphaRelease if version == currentAlphaVersion else version,
|
||||||
'envname': data['sys'][system]['name'],
|
'envname': data['sys'][system]['name'],
|
||||||
}
|
}
|
||||||
for system in systems if system in data['sys']
|
for system, version in combinations if system in data['sys']
|
||||||
for version in versions
|
|
||||||
] + [
|
] + [
|
||||||
{
|
{
|
||||||
'sysicon': data['runtime'][runtime]['icon'],
|
'sysicon': data['runtime'][runtime]['icon'],
|
||||||
@@ -161,8 +206,17 @@ jobs:
|
|||||||
'python': currentMSYS2Version,
|
'python': currentMSYS2Version,
|
||||||
'envname': data['runtime'][runtime]['name'],
|
'envname': data['runtime'][runtime]['name'],
|
||||||
}
|
}
|
||||||
for runtime in systems if runtime not in data['sys']
|
for runtime, version in combinations if runtime not in data['sys']
|
||||||
]
|
]
|
||||||
print(f'::set-output name=python_jobs::{jobs!s}')
|
print(f'::set-output name=python_jobs::{jobs!s}')
|
||||||
print("Python jobs:")
|
|
||||||
pprint(jobs, indent=2)
|
# Format jobs as list of dictionaries
|
||||||
|
buffer = ""
|
||||||
|
for job in jobs:
|
||||||
|
buffer += f" {{ " + ", ".join([f"\"{key}\": \"{value}\"" for key, value in job.items()]) + f" }},\n"
|
||||||
|
|
||||||
|
print(dedent(f"""\
|
||||||
|
Python jobs:
|
||||||
|
[
|
||||||
|
{buffer} ]
|
||||||
|
"""))
|
||||||
|
|||||||
Reference in New Issue
Block a user