vmklib.tasks.release
index
/home/vkottler/src/vkottler/workspace/vmklib/vmklib/tasks/release.py

A module implementing a release task for Python projects.

 
Modules
       
os

 
Classes
       
vmklib.tasks.mixins.curl.CurlMixin(vcorelib.task.subprocess.run.SubprocessLogMixin)
GithubRelease

 
class GithubRelease(vmklib.tasks.mixins.curl.CurlMixin)
    GithubRelease(name: 'str', *args, execute: 'TaskExecute' = None, log: 'Logger' = None, timer: 'Timer' = None, target: 'Target' = None, **kwargs) -> 'None'
 
A task for creating a GitHub release for a given package.
 
 
Method resolution order:
GithubRelease
vmklib.tasks.mixins.curl.CurlMixin
vcorelib.task.subprocess.run.SubprocessLogMixin
vcorelib.task.Task
vcorelib.logging.LoggerMixin
builtins.object

Methods defined here:
async create_release(self, owner: str, repo: str, data: Dict[str, Any]) -> Dict[str, Any]
Attempt to create a release.
async release(self, cwd: pathlib.Path, owner: str, repo: str, version: str, dist: str = 'dist') -> bool
Create a release.
async run(self, inbox: Dict[str, Dict[str, Any]], outbox: Dict[str, Any], *args, **kwargs) -> bool
Generate ninja configuration files.
async upload_release_asset(self, owner: str, repo: str, release_id: int, path: pathlib.Path) -> Dict[str, Any]
Attempt to upload a release asset.

Data and other attributes defined here:
__annotations__ = {}

Methods inherited from vmklib.tasks.mixins.curl.CurlMixin:
async curl(self, *args: str, post_data: Dict[str, Any] = None, headers: Dict[str, str] = None, method: str = None) -> vmklib.tasks.mixins.curl.CommandResult
Run a curl command.

Methods inherited from vcorelib.task.subprocess.run.SubprocessLogMixin:
async exec(self, program: str, *caller_args: str, args: str = '', separator: str = '::', stdout: int = None, stderr: int = None, **kwargs) -> bool
Execute a command and return whether or not it succeeded.
async shell(self, cmd: str, *caller_args: str, args: str = '', joiner: str = ' ', separator: str = '::', stdout: int = None, stderr: int = None, **kwargs) -> bool
Execute a shell command and return whether or not it succeeded.
async shell_cmd_in_dir(self, path: pathlib.Path, cmd: List[str], joiner: str = ' ', cd: str = 'cd', **kwargs) -> bool
Run a shell command in a specific directory.
async subprocess_exec(self, program: str, *caller_args: str, args: str = '', separator: str = '::', stdout: int = None, stderr: int = None, **kwargs) -> asyncio.subprocess.Process
Create a process using subprocess exec and log what the arguments were.
async subprocess_shell(self, cmd: str, *caller_args: str, args: str = '', joiner: str = ' ', separator: str = '::', stdout: int = None, stderr: int = None, **kwargs) -> asyncio.subprocess.Process
Create a process using subprocess shell and log what the command is.

Methods inherited from vcorelib.task.Task:
__init__(self, name: 'str', *args, execute: 'TaskExecute' = None, log: 'Logger' = None, timer: 'Timer' = None, target: 'Target' = None, **kwargs) -> 'None'
Initialize this task.
__str__(self) -> 'str'
Convert this task into a string.
create_execute(self, *args, **kwargs) -> 'TaskExecute'
Create a default execute function for this task.
depend_on(self, task: "'Task'", eloop: '_asyncio.AbstractEventLoop' = None, **kwargs) -> 'bool'
Register other tasks' output data to your input box. Return true
if a new dependency was added.
depend_on_all(self, tasks: "_Iterable['Task']", **kwargs) -> 'int'
Register multiple dependencies. Return the number of dependencies
added.
async dispatch(self, caller: "'Task'" = None, init_only: 'bool' = False, substitutions: 'Substitutions' = None, **kwargs) -> 'None'
Dispatch this task and return whether or not it succeeded.
dispatch_init(self, caller: "'Task'" = None, substitutions: 'Substitutions' = None, **kwargs) -> '_Tuple[Substitutions, str]'
Perform some dispatch initialization.
resolve(self, log: 'Logger', compiled: 'str', substitutions: 'Substitutions' = None) -> 'None'
Mark this task resolved.
async resolve_dependencies(self, **substitutions) -> 'None'
A default dependency resolver for tasks. Note that the default
dependency resolver cannot propagate current-task substitutions to
its dependencies as they've already been explicitly registered.
resolved(self, compiled: 'str', substitutions: 'Substitutions' = None) -> 'bool'
Override this in a derived task to implement more complex logic.
async run_enter(self, _inbox: 'Inbox', _outbox: 'Outbox', *_args, **_kwargs) -> 'bool'
A default enter method.
async run_exit(self, _inbox: 'Inbox', _outbox: 'Outbox', *_args, **_kwargs) -> 'bool'
A default exit method.
task_fail(self, compiled: 'str', substitutions: 'Substitutions', caller: "'Task'" = None, indent: 'int' = 4) -> 'TaskFailed'
Build an exception message for when this task fails.

Readonly properties inherited from vcorelib.task.Task:
stack
Get this task's execution stack.

Data and other attributes inherited from vcorelib.task.Task:
default_requirements = set()
stages = ['run_enter', 'run', 'run_exit']

Methods inherited from vcorelib.logging.LoggerMixin:
log_time(self, message: str, *args, level: int = 20, reminder: bool = False, **kwargs) -> Iterator[NoneType]
A simple wrapper.

Data descriptors inherited from vcorelib.logging.LoggerMixin:
__dict__
dictionary for instance variables
__weakref__
list of weak references to the object

 
Data
        ApiResult = typing.Dict[str, typing.Any]
COMMON_ARGS = ['-L', '-H', 'Accept: application/vnd.github+json', '-H', 'X-GitHub-Api-Version: 2022-11-28']
Dict = typing.Dict
Inbox = typing.Dict[str, typing.Dict[str, typing.Any]]
Outbox = typing.Dict[str, typing.Any]