UNPKG

@installdoc/ansible-gas-station

Version:

An Ansible playbook that provisions your network with software from GitHub Awesome lists, developed with disaster recovery in mind ⛽🔥🤤

159 lines (149 loc) 5.42 kB
--- version: '3' tasks: pip: run: when_changed log: error: Failed to install pip3 package `{{.PACKAGE}}` start: Installing pip3 package `{{.PACKAGE}}` success: Installed pip3 package `{{.PACKAGE}}` cmds: - task: :install:software:python - pip3 install {{.PACKAGE}} status: - type {{.PACKAGE}} > /dev/null pipx: deps: - :install:software:pipx run: when_changed log: error: Failed to install `{{.PACKAGE}}` with pipx start: Installing `{{.PACKAGE}}` with pipx success: Successfully installed `{{.PACKAGE}}` with pipx cmds: - pipx install {{.PACKAGE}} status: - type {{.PACKAGE}} > /dev/null pytest: run: once cmds: - task: pip vars: PACKAGE: pytest pytest-cov: run: once cmds: - task: pip vars: PACKAGE: pytest-cov requirements: run: once cmds: - task: :install:software:python - task: requirements:poetry:prereqs - task: requirements:poetry - task: :{{if eq .REPOSITORY_TYPE "ansible"}}ansible:galaxy:requirements{{else}}donothing{{end}} requirements:poetry: summary: | # Poetry Requirements `poetry publish -r gitlab` will publish to GitLab registry on GitLab CI run: once log: error: Failed to configure / install via `poetry` start: Configuring Poetry and running `poetry install` success: Successfully ran `poetry install` cmds: - task: :install:software:poetry - poetry env use "$(which python3.10)" - poetry config virtualenvs.create {{if .PYTHON_VIRTUALENV}}{{.PYTHON_VIRTUALENV}}{{else}}false{{end}} - poetry config virtualenvs.in-project true - | if [ -n "$PYPI_TOKEN" ]; then poetry config pypi-token.pypi "$PYPI_TOKEN" fi - | if [ -n "$GITLAB_CI" ]; then poetry config repositories.gitlab "https://gitlab.com/api/v4/projects/${CI_PROJECT_ID}/packages/pypi" fi - | if [ -n "$GITLAB_CI" ]; then poetry config http-basic.gitlab gitlab-ci-token "${CI_JOB_TOKEN}" fi - .config/log info "Installing/updating poetry install options -> {{.INSTALL_OPTIONS}}" - | if [ -n "$AUTO_UPDATE_PIP_PACKAGES" ]; then poetry update{{if .INSTALL_OPTIONS}} {{.INSTALL_OPTIONS}}{{end}} else poetry install{{if .INSTALL_OPTIONS}} {{.INSTALL_OPTIONS}}{{end}} fi sources: - pyproject.toml preconditions: - sh: test -f pyproject.toml msg: The `pyproject.toml` file is missing! requirements:poetry:prereqs: vars: GCC5_MISSING_MESSAGE: | It looks like your system is missing gcc-5 but gcc is available. You might be prompted for your sudo password to run the following command: log: error: Error checking `gcc` start: Checking if `gcc` should be symlinked to `gcc-5` success: Checked `gcc` cmds: - | if which gcc; then if [ -w /usr/local/bin ]; then ln -s "$(which gcc)" /usr/local/bin/gcc-5 else .config/log info '{{.GCC5_MISSING_MESSAGE}}' .config/log info '`sudo ln -s '"$(which gcc)"' /usr/local/bin/gcc-5`' sudo ln -s "$(which gcc)" /usr/local/bin/gcc-5 fi else .config/log warn '`gcc` is missing.' fi status: - which gcc-5 venv:node: deps: - :install:software:dasel - :install:software:python vars: POETRY_MANUAL_SETUP_MSG: Adding semantic-release-python plugin Python dependencies by running `poetry add pip@latest setuptools@latest twine@latest wheel@latest` log: error: Encountered error while installing Python dependencies for `semantic-release-python` start: Installing `semantic-release-python` Python dependencies success: Successfully installed `semantic-release-python` Python dependencies cmds: - | REQUIREMENTS_PATH="$PWD/lib/requirements.txt" cd "$INIT_CWD" || exit if type poetry > /dev/null && test -f pyproject.toml; then .config/log info 'Poetry installation detected. Using Poetry to install NPM package Python dependencies.' if dasel select -f pyproject.toml '.tool.poetry.extras.semantic' > /dev/null; then .config/log info '`semantic` extras bundle detected.. Installing via `poetry install -E semantic`' poetry install -E semantic else .config/log info '{{.POETRY_MANUAL_SETUP_MSG}}' poetry add pip@latest setuptools@latest twine@latest wheel@latest fi else if [ -f venv/bin/activate ]; then .config/log info 'Using existing virtualenv found at `venv/`' . venv/bin/activate elif [ -f .venv/bin/activate ]; then .config/log info 'Using existing virtualenv found at `.venv/`' . .venv/bin/activate else .config/log info 'No virtualenv detected.. Creating virtualenv in `.venv/`' python3 -m venv .venv . .venv/bin/activate fi .config/log info 'Installing Python dependencies into virtualenv' pip3 install -U pip setuptools pip3 install -r "$REQUIREMENTS_PATH" fi sources: - lib/requirements.txt