mirror of
https://github.com/jessfraz/dockerfiles.git
synced 2024-11-23 03:21:28 +01:00
add shellcheck
Signed-off-by: Jess Frazelle <acidburn@microsoft.com>
This commit is contained in:
parent
a0a7580a99
commit
544e14ecb0
21
Makefile
21
Makefile
|
@ -7,9 +7,28 @@ latest-versions: ## Checks all the latest versions of the Dockerfile contents.
|
|||
./latest-versions.sh
|
||||
|
||||
.PHONY: test
|
||||
test: ## Runs the tests on the repository.
|
||||
test: shellcheck dockerfiles ## Runs the tests on the repository.
|
||||
|
||||
.PHONY: dockerfiles
|
||||
dockerfiles: ## Tests the changes to the Dockefiles build.
|
||||
./test.sh
|
||||
|
||||
# if this session isn't interactive, then we don't want to allocate a
|
||||
# TTY, which would fail, but if it is interactive, we do want to attach
|
||||
# so that the user can send e.g. ^C through.
|
||||
INTERACTIVE := $(shell [ -t 0 ] && echo 1 || echo 0)
|
||||
ifeq ($(INTERACTIVE), 1)
|
||||
DOCKER_FLAGS += -t
|
||||
endif
|
||||
|
||||
.PHONY: shellcheck
|
||||
shellcheck: ## Runs the shellcheck tests on the scripts.
|
||||
docker run --rm -i $(DOCKER_FLAGS) \
|
||||
--name df-shellcheck \
|
||||
-v $(CURDIR):/usr/src:ro \
|
||||
--workdir /usr/src \
|
||||
r.j3ss.co/shellcheck ./shellcheck.sh
|
||||
|
||||
.PHONY: help
|
||||
help:
|
||||
@grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'
|
||||
|
|
24
shellcheck.sh
Executable file
24
shellcheck.sh
Executable file
|
@ -0,0 +1,24 @@
|
|||
#!/bin/bash
|
||||
set -e
|
||||
set -o pipefail
|
||||
|
||||
ERRORS=()
|
||||
|
||||
# find all executables and run `shellcheck`
|
||||
for f in $(find . -type f -not -iwholename '*.git*' | sort -u); do
|
||||
if file "$f" | grep --quiet shell; then
|
||||
{
|
||||
shellcheck "$f" && echo "[OK]: sucessfully linted $f"
|
||||
} || {
|
||||
# add to errors
|
||||
ERRORS+=("$f")
|
||||
}
|
||||
fi
|
||||
done
|
||||
|
||||
if [ ${#ERRORS[@]} -eq 0 ]; then
|
||||
echo "No errors, hooray"
|
||||
else
|
||||
echo "These files failed shellcheck: ${ERRORS[*]}"
|
||||
exit 1
|
||||
fi
|
Loading…
Reference in New Issue
Block a user