Skip to content

Commit

Permalink
☁️ chore(automation): Applying changes from upstream repository.
Browse files Browse the repository at this point in the history
  • Loading branch information
Megabyte Labs committed Mar 23, 2023
1 parent 20423fc commit acc401e
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 96 deletions.
98 changes: 9 additions & 89 deletions Taskfile.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
---
version: '3'

includes:
ansible:
taskfile: ./.config/taskfiles/ansible/Taskfile.yml
Expand Down Expand Up @@ -185,7 +184,6 @@ includes:
local:
taskfile: ./../../../Taskfile-local.yml
optional: true

log:
optional: true
taskfile: ./.config/taskfiles/log/Taskfile.yml
Expand Down Expand Up @@ -316,7 +314,6 @@ includes:
taskfile: ./.config/taskfiles/web/Taskfile-profile.yml
optional: true
output: interleaved

vars:
DOCKERHUB_PROFILE:
sh: |
Expand Down Expand Up @@ -369,11 +366,7 @@ vars:
GROUP_EXEC_ASYNC: 'false'
# yamllint disable rule:line-length
IGNORE_FOLDERS: >-
-path './.autodoc/*' -o -path './.cache/*' -o -path './.common*' -o -path './.config/*' -o -path './.git/*' -o
-path './.modules/*' -o -path './.npm/*' -o
-path './.pnpm-store/*' -o -path './.shared/*' -o -path './.task/*' -o -path './.venv/*' -o -path './.vscode/*' -o
-path './build/*' -o -path './dist/*' -o -path './node_modules/*' -o -path './roles/*' -o -name pnpm-lock.yaml -o
-name package-lock.json -o -name poetry.lock -o -name '.variables.json' -o -name '.git'
-path './.autodoc/*' -o -path './.cache/*' -o -path './.common*' -o -path './.config/*' -o -path './.git/*' -o -path './.modules/*' -o -path './.npm/*' -o -path './.pnpm-store/*' -o -path './.shared/*' -o -path './.task/*' -o -path './.venv/*' -o -path './.vscode/*' -o -path './build/*' -o -path './dist/*' -o -path './node_modules/*' -o -path './roles/*' -o -name pnpm-lock.yaml -o -name package-lock.json -o -name poetry.lock -o -name '.variables.json' -o -name '.git'
INIT_SCRIPT: https://gitlab.com/megabyte-labs/gitlab-ci/-/raw/master/scripts/update-init.sh
LOG_FIX:
sh: chmod +x .config/log
Expand Down Expand Up @@ -405,34 +398,13 @@ vars:
fi
PYTHON_VIRTUALENV: true
REPOSITORY_SUBTYPE:
sh: |
if [ -n "$REPOSITORY_TYPE" ]; then REPO_SUBTYPE="$REPOSITORY_TYPE"; fi
if type jq &> /dev/null && [ -f package.json ]; then
VER="$(jq -r '.blueprint.subgroup' package.json)"
if [ "$VER" == 'null' ]; then
if [ -n "$REPO_SUBTYPE" ]; then echo "$REPO_SUBTYPE"; else echo "misc"; fi
else
echo "$VER"
fi
else
if [ -n "$REPO_SUBTYPE" ]; then echo "$REPO_SUBTYPE"; else echo "misc"; fi
fi
sh: if type jq &> /dev/null && [ -f package.json ]; then VER="$(jq -r .blueprint.subgroup package.json)"; if [ "$VER" == null ]; then echo "$REPOSITORY_TYPE"; else echo "$VER"; fi; else echo "$REPOSITORY_TYPE"; fi
REPOSITORY_TYPE:
sh: |
if [ -n "$GROUP_TYPE" ]; then REPO_TYPE="$GROUP_TYPE"; fi
if type jq &> /dev/null && [ -f package.json ]; then
VER="$(jq -r '.blueprint.group' package.json)"
if [ "$VER" == 'null' ]; then
if [ -n "$REPO_TYPE" ]; then echo "$REPO_TYPE"; else echo "misc"; fi
else
echo "$VER"
fi
else
if [ -n "$REPO_TYPE" ]; then echo "$REPO_TYPE"; else echo "misc"; fi
fi
sh: if type jq &> /dev/null && [ -f package.json ]; then VER="$(jq -r .blueprint.group package.json)"; if [ "$VER" == null ]; then echo "$GROUP_TYPE"; else echo "$VER"; fi; else echo "$GROUP_TYPE"; fi
SEMANTIC_CONFIG: semantic-release-config
TIMEZONE: America/New_York

includes:
common:start: ./.config/taskfiles/common/Taskfile-start.yml
env:
GOPATH:
sh: |
Expand Down Expand Up @@ -465,7 +437,6 @@ env:
fi
VOLTA_HOME:
sh: echo "$HOME/.volta"

profile: |
if [[ "$OSTYPE" == 'linux-gnu'* ]] || [[ "$OSTYPE" == 'linux-musl'* ]]; then
if [ -f /home/linuxbrew/.linuxbrew/bin/brew ] && ! type brew > /dev/null; then
Expand All @@ -484,7 +455,6 @@ profile: |
if [ -f .venv/bin/activate ]; then
. .venv/bin/activate
fi
tasks:
build:
deps:
Expand Down Expand Up @@ -513,7 +483,6 @@ tasks:
else
[[ $- == *i* ]] && task prepare || (.config/log error '{{.NONINTERACTIVE_MISSING_BUILD_CMD}}' && exit 1)
fi
clean:
desc: Removes optional folders that are cached during various tasks
summary: |
Expand All @@ -524,13 +493,11 @@ tasks:
which will re-generate the project from scratch. Ideally, this task and the reset task
should never be necessary. The `start` task should be used instead.
vars:
CLEAN_TARGETS: .autodoc .cache .task .venv node_modules tsconfig.tsbuildinfo venv
.variables.json
CLEAN_TARGETS: .autodoc .cache .task .venv node_modules tsconfig.tsbuildinfo venv .variables.json
cmds:
- task: common:clean
vars:
CLEAN_TARGETS: '{{.CLEAN_TARGETS}}'

commit:
desc: Lint staged files, report spelling errors, and open a _required_ commit dialoge
summary: |
Expand All @@ -547,7 +514,6 @@ tasks:
to your regular `git commit -m` command to bypass the pre-commit hook.
cmds:
- task: common:commit

commit:all:
deps:
- install:software:git
Expand Down Expand Up @@ -585,26 +551,20 @@ tasks:
git add --all
git commit
{{end}}
commit:quick:
deps:
- ci:commit:config
cmds:
- |
task --list > /dev/null || (echo "ERROR: Invalid Taskfiles!" && exit 1)
git add --all
- |
.config/log info 'Bypassing git hooks for git commit'
HUSKY=0 git commit -m "🔧 chore(tweak): quick minor update" --no-verify
- ".config/log info 'Bypassing git hooks for git commit'\nHUSKY=0 git commit -m \"\U0001F527 chore(tweak): quick minor update\" --no-verify\n"
- git push origin master

devcontainer:
deps:
- install:npm:devcontainer
- install:software:docker

donothing: 'true'

fix:
desc: Run code auto-fixers / auto-formatters
summary: |
Expand All @@ -615,7 +575,6 @@ tasks:
an error so the auto-fixes still have to be validated.
cmds:
- task: fix:all

fresh:
summary: Initialize a new project with only the Taskfile.yml present
cmds:
Expand All @@ -627,7 +586,6 @@ tasks:
- TMP="$(mktemp)" && jq -r 'del(.blueprint)' package.json > "$TMP" && mv "$TMP" package.json
- bash start.sh
- task: prepare

get:links:
deps:
- install:software:jq
Expand All @@ -640,7 +598,6 @@ tasks:
cmds:
- .config/log info 'GitHub -----> `{{.GITHUB_URL}}`'
- .config/log info 'GitLab -----> `{{.GITLAB_URL}}`'

group:exec:
desc: Execute group commands on any GitLab group (including repositories in sub-groups)
summary: |
Expand All @@ -661,7 +618,6 @@ tasks:
Be sure to wrap the command in quotes or you might observe some odd behavior.
cmds:
- task: git:gitlab:group:exec

init:
deps:
- install:software:jq
Expand Down Expand Up @@ -694,12 +650,10 @@ tasks:
- git init
- task: repair
- task: prepare

jumpusb:
desc: Creates a JumpUSB (https://jumpusb.com)
cmds:
- task: install:ventoy

lint:
desc: Lints the project using all linters
summary: |
Expand All @@ -713,7 +667,6 @@ tasks:
`task lint`
cmds:
- task: lint:all

livereload:
deps:
- install:npm:nodemon
Expand Down Expand Up @@ -753,12 +706,10 @@ tasks:
.config/log error '`Taskfile-project.yml` must exist and have a `livereload` task to use with `nodemon`' && exit 1
fi
- nodemon --config {{if .CLI_ARGS}}{{.CLI_ARGS}}{{else}}.config/nodemon.json{{end}}

new:project:
desc: Create a new project
cmds:
- task: prepare

preload:
desc: Set up your workstation in advance by installing commonly used programs
summary: |
Expand Down Expand Up @@ -801,7 +752,6 @@ tasks:
- task: install:pipx:bundle
- task: install:python:requirements
- task: install:modules:local

prepare:
desc: Prepares the project for the normal start command
summary: |
Expand All @@ -818,7 +768,6 @@ tasks:
cmds:
- task: boilerplate:check:package
- task: boilerplate:clean

publish:
desc: Publish a semantic release via `semantic-release`
summary: |
Expand Down Expand Up @@ -866,7 +815,6 @@ tasks:
success: Successfully ran `semantic-release` via `task publish`
cmds:
- task: publish:semantic-release

publish:force:
desc: Force a `semantic-release` even if there are no new eligible commits
summary: |
Expand All @@ -892,11 +840,8 @@ tasks:
start: Publishing `semantic-release` update via `task publish:force`
success: Successfully published update via `task publish:force`
cmds:
- |
.config/log info 'Bypassing git hooks for git commit'
HUSKY=0 git commit -a --allow-empty -m '🔨 chore(bump): Forced semantic-release {{.UPDATE_LEVEL}}' --no-verify
- ".config/log info 'Bypassing git hooks for git commit'\nHUSKY=0 git commit -a --allow-empty -m '\U0001F528 chore(bump): Forced semantic-release {{.UPDATE_LEVEL}}' --no-verify\n"
- task: publish

pull:upstream:
desc: Pull from upstream repositories
summary: |
Expand All @@ -913,7 +858,6 @@ tasks:
success: Successfully pulled from `upstreamRemotes`
cmds:
- task: common:update:upstream:remotes:pull

repair:
cmds:
- task: common:repair
Expand All @@ -924,7 +868,6 @@ tasks:
else
curl -sSL {{.INIT_SCRIPT}} > "$TMP" && bash "$TMP" && rm "$TMP"
fi
reset:
desc: Resets the project by removing all caches and then re-generating templated files
summary: |
Expand All @@ -936,7 +879,6 @@ tasks:
updates, it re-generates any templated files.
cmds:
- task: common:reset

reset:force:
desc: 'Aggressively reset the project (**WARNING** This will wipe uncommitted work)'
summary: |
Expand All @@ -955,7 +897,6 @@ tasks:
answer:
cmds:
- task: common:reset:force

scripts:
interactive: true
deps:
Expand All @@ -973,7 +914,6 @@ tasks:
start: Running `NTL_RUNNER={{.NPM_PROGRAM}} ntl`
cmds:
- NTL_RUNNER={{.NPM_PROGRAM}} ntl

services:
desc: Update elements of the repository that require API access
summary: |
Expand All @@ -986,7 +926,6 @@ tasks:
- task: common:update:services
status:
- '[ -n "$GITLAB_CI" ] && [ "$REPOSITORY_UPDATE" != "true" ]'

shell:
desc: Start a terminal session using Docker with any Linux operating system
compile: |
Expand Down Expand Up @@ -1020,13 +959,11 @@ tasks:
* ubuntu-21.04
cmds:
- task: common:shell

ssh-keys:
deps:
- cloud:heroku:ssh-keys
- git:github:ssh-keys
- git:gitlab:ssh-keys

start:
desc: Start the project by installing / updating dependencies, repairing issues, and opening a tutorial
summary: |
Expand All @@ -1050,7 +987,6 @@ tasks:
success: Project started!
cmds:
- task: common:start

synchronize:
desc: Set up the project and refresh it with the latest changes
summary: |
Expand All @@ -1071,7 +1007,6 @@ tasks:
success: Successfully synchronized the project with upstream file changes and also bootstrapped the project
cmds:
- task: upstream:{{.PROJECT_TYPE}}

tag:deps:
desc: Inject a new command in the `Taskfile.yml` that includes all tasks matching a given tag as deps
summary: |
Expand Down Expand Up @@ -1100,7 +1035,6 @@ tasks:
```
cmds:
- task: common:util:task:tag:deps

template:
deps:
- install:npm:liquidjs
Expand All @@ -1122,7 +1056,6 @@ tasks:
preconditions:
- sh: test -f .variables.json
msg: This task requires that you have already spun up the project by running `task start`

test:
deps:
- install:software:jq
Expand All @@ -1134,16 +1067,6 @@ tasks:
This task calls `npm run test` which functions differently based on the
definition made in `package.json` under the `.scripts.test` key.
## Ansible Project Functionality
For Ansible projects, this task wraps all the supported test methods for Ansible plays into a
convenient multi-question prompt system that supports:
1. Docker tests
2. Headless VirtualBox tests
3. VirtualBox Desktop tests which are not automatically destroyed
4. Running the play locally
5. Running the play over SSH on a remote target
vars:
NONINTERACTIVE_MISSING_TEST_CMD: There must be a `.scripts.test` definition in `package.json`!
cmds:
Expand All @@ -1153,7 +1076,6 @@ tasks:
else
[[ $- == *i* ]] && task prepare || (.config/log error '{{.NONINTERACTIVE_MISSING_TEST_CMD}}' && exit 1)
fi
update:
desc: Fully update the repository
summary: |
Expand All @@ -1180,9 +1102,7 @@ tasks:
cmds:
- task: common:start
env:
UPDATE_PROJECT: 'true'
- task: common:update:finish

UPDATE_PROJECT: "true"
yubikey:
desc: Create an OpenGPG-enabled YubiKey
summary: |
Expand Down
2 changes: 1 addition & 1 deletion meta/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ galaxy_info:
company: Megabyte Labs
issue_tracker_url: https://gitlab.com/megabyte-labs/ansible-roles/rust/-/issues
license: license (MIT)
min_ansible_version: 2.1
min_ansible_version: 2.10
platforms:
- name: Mac
versions:
Expand Down
Loading

0 comments on commit acc401e

Please sign in to comment.