mirror of
https://github.com/valitydev/grafanalib.git
synced 2024-11-06 10:15:24 +00:00
46b8099b5c
35679ee Merge pull request #110 from weaveworks/parallel-push-errors 3ae41b6 Remove unneeded if block 51ff31a Exit on first error 0faad9f Check for errors when pushing images in parallel 74dc626 Merge pull request #108 from weaveworks/disable-apt-daily b4f1d91 Merge pull request #107 from weaveworks/docker-17-update 7436aa1 Override apt daily job to not run immediately on boot 7980f15 Merge pull request #106 from weaveworks/document-docker-install-role f741e53 Bump to Docker 17.06 from CE repo 61796a1 Update Docker CE Debian repo details 0d86f5e Allow for Docker package to be named docker-ce 065c68d Document selection of Docker installation role. 3809053 Just --porcelain; it defaults to v1 11400ea Merge pull request #105 from weaveworks/remove-weaveplugin-remnants b8b4d64 remove weaveplugin remnants 35099c9 Merge pull request #104 from weaveworks/pull-docker-py cdd48fc Pull docker-py to speed tests/builds up. e1c6c24 Merge pull request #103 from weaveworks/test-build-tags d5d71e0 Add -tags option so callers can pass in build tags 8949b2b Merge pull request #98 from weaveworks/git-status-tag ac30687 Merge pull request #100 from weaveworks/python_linting 4b125b5 Pin yapf & flake8 versions 7efb485 Lint python linting function 444755b Swap diff direction to reflect changes required c5b2434 Install flake8 & yapf 5600eac Lint python in build-tools repo 0b02ca9 Add python linting c011c0d Merge pull request #79 from kinvolk/schu/python-shebang 6577d07 Merge pull request #99 from weaveworks/shfmt-version 00ce0dc Use git status instead of diff to add 'WIP' tag 411fd13 Use shfmt v1.3.0 instead of latest from master. 0d6d4da Run shfmt 1.3 on the code. 5cdba32 Add sudo c322ca8 circle.yml: Install shfmt binary. e59c225 Install shfmt 1.3 binary. 30706e6 Install pyhcl in the build container. 960d222 Merge pull request #97 from kinvolk/alban/update-shfmt-3 1d535c7 shellcheck: fix escaping issue 5542498 Merge pull request #96 from kinvolk/alban/update-shfmt-2 32f7cc5 shfmt: fix coding style 09f72af lint: print the diff in case of error 571c7d7 Merge pull request #95 from kinvolk/alban/update-shfmt bead6ed Update for latest shfmt b08dc4d Update for latest shfmt (#94) 2ed8aaa Add no-race argument to test script (#92) 80dd78e Merge pull request #91 from weaveworks/upgrade-go-1.8.1 08dcd0d Please ./lint as shfmt changed its rules between 1.0.0 and 1.3.0. a8bc9ab Upgrade default Go version to 1.8.1. 41c5622 Merge pull request #90 from weaveworks/build-golang-service-conf e8ebdd5 broaden imagetag regex to fix haskell build image ba3fbfa Merge pull request #89 from weaveworks/build-golang-service-conf e506f1b Fix up test script for updated shfmt 9216db8 Add stuff for service-conf build to build-goland image 66a9a93 Merge pull request #88 from weaveworks/haskell-image cb3e3a2 shfmt 74a5239 Haskell build image 4ccd42b Trying circle quay login b2c295f Merge branch 'common-build' 0ac746f Trim quay prefix in circle script c405b31 Merge pull request #87 from weaveworks/common-build 9672d7c Push build images to quay as they have sane robot accounts a2bf112 Review feedback fef9b7d Add protobuf tools 10a77ea Update readme 254f266 Don't need the image name in ffb59fc Adding a weaveworks/build-golang image with tags b817368 Update min Weave Net docker version cf87ca3 Merge pull request #86 from weaveworks/lock-kubeadm-version 3ae6919 Add example of custom SSH private key to tf_ssh's usage. cf8bd8a Add example of custom SSH private key to tf_ansi's usage. c7d3370 Lock kubeadm's Kubernetes version. faaaa6f Merge pull request #84 from weaveworks/centos-rhel ef552e7 Select weave-kube YAML URL based on K8S version. b4c1198 Upgrade default kubernetes_version to 1.6.1. b82805e Use a fixed version of kubeadm. f33888b Factorise and make kubeconfig option optional. f7b8b89 Install EPEL repo for CentOS. 615917a Fix error in decrypting AWS access key and secret. 86f97b4 Add CentOS 7 AMI and username for AWS via Terraform. eafd810 Add tf_ansi example with Ansible variables. 2b05787 Skip setup of Docker over TCP for CentOS/RHEL. 84c420b Add docker-ce role for CentOS/RHEL. 00a820c Add setup_weave-net_debug.yml playbook for user issues' debugging. 3eae480 Upgrade default kubernetes_version to 1.5.4. 753921c Allow injection of Docker installation role. e1ff90d Fix kubectl taint command for 1.5. b989e97 Fix typo in kubectl taint for single node K8S cluster. 541f58d Remove 'install_recommends: no' for ethtool. c3f9711 Make Ansible role docker-from-get.docker.com work on RHEL/CentOS. 038c0ae Add frequently used OS images, for convenience. d30649f Add --insecure-registry to docker.conf 1dd9218 shfmt -i 4 -w push-images 6de96ac Add option to not push docker hub images 310f53d Add push-images script from cortex 8641381 Add port 6443 to kubeadm join commands for K8S 1.6+. 50bf0bc Force type of K8S token to string. 08ab1c0 Remove trailing whitespaces. ae9efb8 Enable testing against K8S release candidates. 9e32194 Secure GCP servers for Scope: open port 80. a22536a Secure GCP servers for Scope. 89c3a29 Merge pull request #78 from weaveworks/lint-merge-rebase-issue-in-docs 73ad56d Add linter function to avoid bad merge/rebase artefact 31d069d Change Python shebang to `#!/usr/bin/env python` 52d695c Merge pull request #77 from kinvolk/schu/fix-relative-weave-path 77aed01 Merge pull request #73 from weaveworks/mike/sched/fix-unicode-issue 7c080f4 integration/sanity_check: disable SC1090 d6d360a integration/gce.sh: update gcloud command e8def2c provisioning/setup: fix shellcheck SC2140 cc02224 integration/config: fix weave path 9c0d6a5 Fix config_management/README.md 334708c Merge pull request #75 from kinvolk/alban/external-build-1 da2505d gce.sh: template: print creation date e676854 integration tests: fix user account 8530836 host nameing: add repo name b556c0a gce.sh: fix deletion of gce instances 2ecd1c2 integration: fix GCE --zones/--zone parameter 3e863df sched: Fix unicode encoding issues 51785b5 Use rm -f and set current dir using BASH_SOURCE. f5c6d68 Merge pull request #71 from kinvolk/schu/fix-linter-warnings 0269628 Document requirement for `lint_sh` 9a3f09e Fix linter warnings efcf9d2 Merge pull request #53 from weaveworks/2647-testing-mvp d31ea57 Weave Kube playbook now works with multiple nodes. 27868dd Add GCP firewall rule for FastDP crypto. edc8bb3 Differentiated name of dev and test playbooks, to avoid confusion. efa3df7 Moved utility Ansible Yaml to library directory. fcd2769 Add shorthands to run Ansible playbooks against Terraform-provisioned virtual machines. f7946fb Add shorthands to SSH into Terraform-provisioned virtual machines. aad5c6f Mention Terraform and Ansible in README.md. dddabf0 Add Terraform output required for templates' creation. dcc7d02 Add Ansible configuration playbooks for development environments. f86481c Add Ansible configuration playbooks for Docker, K8S and Weave-Net. efedd25 Git-ignore Ansible retry files. 765c4ca Add helper functions to setup Terraform programmatically. 801dd1d Add Terraform cloud provisioning scripts. b8017e1 Install hclfmt on CircleCI. 4815e19 Git-ignore Terraform state files. 0aaebc7 Add script to generate cartesian product of dependencies of cross-version testing. 007d90a Add script to list OS images from GCP, AWS and DO. ca65cc0 Add script to list relevant versions of Go, Docker and Kubernetes. aa66f44 Scripts now source dependencies using absolute path (previously breaking make depending on current directory). 7865e86 Add -p option to parallelise lint. 36c1835 Merge pull request #69 from weaveworks/mflag 9857568 Use mflag and mflagext package from weaveworks/common. 9799112 Quote bash variable. 10a36b3 Merge pull request #67 from weaveworks/shfmt-ignore a59884f Add support for .lintignore. 03cc598 Don't lint generated protobuf code. 2b55c2d Merge pull request #66 from weaveworks/reduce-test-timeout d4e163c Make timeout a flag 49a8609 Reduce test timeout 8fa15cb Merge pull request #63 from weaveworks/test-defaults b783528 Tweak test script so it can be run on a mca a3b18bf Merge pull request #65 from weaveworks/fix-integration-tests ecb5602 Fix integration tests f9dcbf6 ... without tab (clearly not my day) a6215c3 Add break I forgot 0e6832d Remove incorrectly added tab eb26c68 Merge pull request #64 from weaveworks/remove-test-package-linting f088e83 Review feedback 2c6e83e Remove test package linting 2b3a1bb Merge pull request #62 from weaveworks/revert-61-test-defaults 8c3883a Revert "Make no-go-get the default, and don't assume -tags netgo" e75c226 Fix bug in GC of firewall rules. e49754e Merge pull request #51 from weaveworks/gc-firewall-rules 191f487 Add flag to enale/disable firewall rules' GC. 567905c Add GC of firewall rules for weave-net-tests to scheduler. 03119e1 Fix typo in GC of firewall rules. bbe3844 Fix regular expression for firewall rules. c5c23ce Pre-change refactoring: splitted gc_project function into smaller methods for better readability. ed5529f GC firewall rules ed8e757 Merge pull request #61 from weaveworks/test-defaults 57856e6 Merge pull request #56 from weaveworks/remove-wcloud dd5f3e6 Add -p flag to test, run test in parallel 62f6f94 Make no-go-get the default, and don't assume -tags netgo 8946588 Merge pull request #60 from weaveworks/2647-gc-weave-net-tests 4085df9 Scheduler now also garbage-collects VMs from weave-net-tests. 4b7d5c6 Merge pull request #59 from weaveworks/57-fix-lint-properly b7f0e69 Merge pull request #58 from weaveworks/fix-lint 794702c Pin version of shfmt ab1b11d Fix lint d1a5e46 Remove wcloud cli tool git-subtree-dir: tools git-subtree-split: 35679ee5ff17c4edf864b7c43dc70a40337fcd80
256 lines
6.6 KiB
Bash
Executable File
256 lines
6.6 KiB
Bash
Executable File
#!/bin/bash
|
|
# This scipt lints files for common errors.
|
|
#
|
|
# For go files, it runs gofmt and go vet, and optionally golint and
|
|
# gocyclo, if they are installed.
|
|
#
|
|
# For shell files, it runs shfmt. If you don't have that installed, you can get
|
|
# it with:
|
|
# go get -u gopkg.in/mvdan/sh.v1/cmd/shfmt
|
|
#
|
|
# With no arguments, it lints the current files staged
|
|
# for git commit. Or you can pass it explicit filenames
|
|
# (or directories) and it will lint them.
|
|
#
|
|
# To use this script automatically, run:
|
|
# ln -s ../../bin/lint .git/hooks/pre-commit
|
|
|
|
set -e
|
|
|
|
LINT_IGNORE_FILE=${LINT_IGNORE_FILE:-".lintignore"}
|
|
|
|
IGNORE_LINT_COMMENT=
|
|
IGNORE_SPELLINGS=
|
|
PARALLEL=
|
|
while true; do
|
|
case "$1" in
|
|
-nocomment)
|
|
IGNORE_LINT_COMMENT=1
|
|
shift 1
|
|
;;
|
|
-notestpackage)
|
|
# NOOP, still accepted for backwards compatibility
|
|
shift 1
|
|
;;
|
|
-ignorespelling)
|
|
IGNORE_SPELLINGS="$2,$IGNORE_SPELLINGS"
|
|
shift 2
|
|
;;
|
|
-p)
|
|
PARALLEL=1
|
|
shift 1
|
|
;;
|
|
*)
|
|
break
|
|
;;
|
|
esac
|
|
done
|
|
|
|
spell_check() {
|
|
local filename="$1"
|
|
local lint_result=0
|
|
|
|
# we don't want to spell check tar balls, binaries, Makefile and json files
|
|
if file "$filename" | grep executable >/dev/null 2>&1; then
|
|
return $lint_result
|
|
fi
|
|
if [[ $filename == *".tar" || $filename == *".gz" || $filename == *".json" || $(basename "$filename") == "Makefile" ]]; then
|
|
return $lint_result
|
|
fi
|
|
|
|
# misspell is completely optional. If you don't like it
|
|
# don't have it installed.
|
|
if ! type misspell >/dev/null 2>&1; then
|
|
return $lint_result
|
|
fi
|
|
|
|
if ! misspell -error -i "$IGNORE_SPELLINGS" "${filename}"; then
|
|
lint_result=1
|
|
fi
|
|
|
|
return $lint_result
|
|
}
|
|
|
|
lint_go() {
|
|
local filename="$1"
|
|
local lint_result=0
|
|
|
|
if [ -n "$(gofmt -s -l "${filename}")" ]; then
|
|
lint_result=1
|
|
echo "${filename}: run gofmt -s -w ${filename}"
|
|
fi
|
|
|
|
go tool vet "${filename}" || lint_result=$?
|
|
|
|
# golint is completely optional. If you don't like it
|
|
# don't have it installed.
|
|
if type golint >/dev/null 2>&1; then
|
|
# golint doesn't set an exit code it seems
|
|
if [ -z "$IGNORE_LINT_COMMENT" ]; then
|
|
lintoutput=$(golint "${filename}")
|
|
else
|
|
lintoutput=$(golint "${filename}" | grep -vE 'comment|dot imports|ALL_CAPS')
|
|
fi
|
|
if [ -n "$lintoutput" ]; then
|
|
lint_result=1
|
|
echo "$lintoutput"
|
|
fi
|
|
fi
|
|
|
|
# gocyclo is completely optional. If you don't like it
|
|
# don't have it installed. Also never blocks a commit,
|
|
# it just warns.
|
|
if type gocyclo >/dev/null 2>&1; then
|
|
gocyclo -over 25 "${filename}" | while read -r line; do
|
|
echo "${filename}": higher than 25 cyclomatic complexity - "${line}"
|
|
done
|
|
fi
|
|
|
|
return $lint_result
|
|
}
|
|
|
|
lint_sh() {
|
|
local filename="$1"
|
|
local lint_result=0
|
|
|
|
if ! diff -u "${filename}" <(shfmt -i 4 "${filename}"); then
|
|
lint_result=1
|
|
echo "${filename}: run shfmt -i 4 -w ${filename}"
|
|
fi
|
|
|
|
# the shellcheck is completely optional. If you don't like it
|
|
# don't have it installed.
|
|
if type shellcheck >/dev/null 2>&1; then
|
|
shellcheck "${filename}" || lint_result=1
|
|
fi
|
|
|
|
return $lint_result
|
|
}
|
|
|
|
lint_tf() {
|
|
local filename="$1"
|
|
local lint_result=0
|
|
|
|
if ! diff -u <(hclfmt "${filename}") "${filename}"; then
|
|
lint_result=1
|
|
echo "${filename}: run hclfmt -w ${filename}"
|
|
fi
|
|
|
|
return $lint_result
|
|
}
|
|
|
|
lint_md() {
|
|
local filename="$1"
|
|
local lint_result=0
|
|
|
|
for i in '=======' '>>>>>>>'; do
|
|
if grep -q "${i}" "${filename}"; then
|
|
lint_result=1
|
|
echo "${filename}: bad merge/rebase!"
|
|
fi
|
|
done
|
|
|
|
return $lint_result
|
|
}
|
|
|
|
lint_py() {
|
|
local filename="$1"
|
|
local lint_result=0
|
|
|
|
if yapf --diff "${filename}" | grep -qE '^[+-]'; then
|
|
lint_result=1
|
|
echo "${filename}: run yapf --in-place ${filename}"
|
|
else
|
|
# Only run flake8 if yapf passes, since they pick up a lot of similar issues
|
|
flake8 "${filename}" || lint_result=1
|
|
fi
|
|
|
|
return $lint_result
|
|
}
|
|
|
|
lint() {
|
|
filename="$1"
|
|
ext="${filename##*\.}"
|
|
local lint_result=0
|
|
|
|
# Don't lint deleted files
|
|
if [ ! -f "$filename" ]; then
|
|
return
|
|
fi
|
|
|
|
# Don't lint specific files
|
|
case "$(basename "${filename}")" in
|
|
static.go) return ;;
|
|
coverage.html) return ;;
|
|
*.pb.go) return ;;
|
|
esac
|
|
|
|
if [[ "$(file --mime-type "${filename}" | awk '{print $2}')" == "text/x-shellscript" ]]; then
|
|
ext="sh"
|
|
fi
|
|
|
|
case "$ext" in
|
|
go) lint_go "${filename}" || lint_result=1 ;;
|
|
sh) lint_sh "${filename}" || lint_result=1 ;;
|
|
tf) lint_tf "${filename}" || lint_result=1 ;;
|
|
md) lint_md "${filename}" || lint_result=1 ;;
|
|
py) lint_py "${filename}" || lint_result=1 ;;
|
|
esac
|
|
|
|
spell_check "${filename}" || lint_result=1
|
|
|
|
return $lint_result
|
|
}
|
|
|
|
lint_files() {
|
|
local lint_result=0
|
|
while read -r filename; do
|
|
lint "${filename}" || lint_result=1
|
|
done
|
|
exit $lint_result
|
|
}
|
|
|
|
matches_any() {
|
|
local filename="$1"
|
|
local patterns="$2"
|
|
while read -r pattern; do
|
|
# shellcheck disable=SC2053
|
|
# Use the [[ operator without quotes on $pattern
|
|
# in order to "glob" the provided filename:
|
|
[[ "$filename" == $pattern ]] && return 0
|
|
done <<<"$patterns"
|
|
return 1
|
|
}
|
|
|
|
filter_out() {
|
|
local patterns_file="$1"
|
|
if [ -n "$patterns_file" ] && [ -r "$patterns_file" ]; then
|
|
local patterns
|
|
patterns=$(sed '/^#.*$/d ; /^\s*$/d' "$patterns_file") # Remove blank lines and comments before we start iterating.
|
|
[ -n "$DEBUG" ] && echo >&2 "> Filters:" && echo >&2 "$patterns"
|
|
local filtered_out=()
|
|
while read -r filename; do
|
|
matches_any "$filename" "$patterns" && filtered_out+=("$filename") || echo "$filename"
|
|
done
|
|
[ -n "$DEBUG" ] && echo >&2 "> Files filtered out (i.e. NOT linted):" && printf >&2 '%s\n' "${filtered_out[@]}"
|
|
else
|
|
cat # No patterns provided: simply propagate stdin to stdout.
|
|
fi
|
|
}
|
|
|
|
list_files() {
|
|
if [ $# -gt 0 ]; then
|
|
find "$@" | grep -vE '(^|/)vendor/'
|
|
else
|
|
git ls-files --exclude-standard | grep -vE '(^|/)vendor/'
|
|
fi
|
|
}
|
|
|
|
if [ $# = 1 ] && [ -f "$1" ]; then
|
|
lint "$1"
|
|
elif [ -n "$PARALLEL" ]; then
|
|
list_files "$@" | filter_out "$LINT_IGNORE_FILE" | xargs -n1 -P16 "$0"
|
|
else
|
|
list_files "$@" | filter_out "$LINT_IGNORE_FILE" | lint_files
|
|
fi
|