mirror of
https://github.com/AdguardTeam/AdGuardDNS.git
synced 2025-02-20 11:23:36 +08:00
237 lines
6.0 KiB
Bash
237 lines
6.0 KiB
Bash
#!/bin/sh
|
|
|
|
# This comment is used to simplify checking local copies of the script. Bump
|
|
# this number every time a significant change is made to this script.
|
|
#
|
|
# AdGuard-Project-Version: 12
|
|
|
|
verbose="${VERBOSE:-0}"
|
|
readonly verbose
|
|
|
|
if [ "$verbose" -gt '0' ]; then
|
|
set -x
|
|
fi
|
|
|
|
# Set $EXIT_ON_ERROR to zero to see all errors.
|
|
if [ "${EXIT_ON_ERROR:-1}" -eq '0' ]; then
|
|
set +e
|
|
else
|
|
set -e
|
|
fi
|
|
|
|
set -f -u
|
|
|
|
# Source the common helpers, including not_found and run_linter.
|
|
. ./scripts/make/helper.sh
|
|
|
|
# Simple analyzers
|
|
|
|
# blocklist_imports is a simple check against unwanted packages. The following
|
|
# packages are banned:
|
|
#
|
|
# * Package errors is replaced by our own package in the
|
|
# github.com/AdguardTeam/golibs module.
|
|
#
|
|
# * Packages log and github.com/AdguardTeam/golibs/log are replaced by
|
|
# stdlib's new package log/slog and AdGuard's new utilities package
|
|
# github.com/AdguardTeam/golibs/logutil/slogutil.
|
|
#
|
|
# * Package github.com/prometheus/client_golang/prometheus/promauto is not
|
|
# recommended, as it encourages reliance on global state.
|
|
#
|
|
# * Packages golang.org/x/exp/maps, golang.org/x/exp/slices, and
|
|
# golang.org/x/net/context have been moved into stdlib.
|
|
#
|
|
# * Package io/ioutil is soft-deprecated.
|
|
#
|
|
# * Package reflect is often an overkill, and for deep comparisons there are
|
|
# much better functions in module github.com/google/go-cmp. Which is
|
|
# already our indirect dependency and which may or may not enter the stdlib
|
|
# at some point.
|
|
#
|
|
# See https://github.com/golang/go/issues/45200.
|
|
#
|
|
# * Package sort is replaced by package slices.
|
|
#
|
|
# * Package unsafe is… unsafe.
|
|
#
|
|
# Currently, the only standard exception are files generated from protobuf
|
|
# schemas, which use package reflect. If your project needs more exceptions,
|
|
# add and document them.
|
|
#
|
|
# NOTE: Flag -H for grep is non-POSIX but all of Busybox, GNU, macOS, and
|
|
# OpenBSD support it.
|
|
#
|
|
# NOTE: For AdGuard DNS, there are the following exceptions:
|
|
#
|
|
# * internal/profiledb/internal/filecachepb/unsafe.go: a “safe” unsafe helper
|
|
# to prevent excessive allocations.
|
|
#
|
|
# TODO(a.garipov): Add golibs/log, client_golang/prometheus/promauto.
|
|
blocklist_imports() {
|
|
find . \
|
|
-type 'f' \
|
|
'(' \
|
|
-name '*.go' \
|
|
'!' -name '*.pb.go' \
|
|
'!' -path './internal/profiledb/internal/filecachepb/unsafe.go' \
|
|
')' \
|
|
-exec \
|
|
'grep' \
|
|
'-H' \
|
|
'-e' '[[:space:]]"errors"$' \
|
|
'-e' '[[:space:]]"golang.org/x/exp/maps"$' \
|
|
'-e' '[[:space:]]"golang.org/x/exp/slices"$' \
|
|
'-e' '[[:space:]]"golang.org/x/net/context"$' \
|
|
'-e' '[[:space:]]"io/ioutil"$' \
|
|
'-e' '[[:space:]]"log"$' \
|
|
'-e' '[[:space:]]"reflect"$' \
|
|
'-e' '[[:space:]]"sort"$' \
|
|
'-e' '[[:space:]]"unsafe"$' \
|
|
'-n' \
|
|
'{}' \
|
|
';'
|
|
}
|
|
|
|
# method_const is a simple check against the usage of some raw strings and
|
|
# numbers where one should use named constants.
|
|
#
|
|
# NOTE: Flag -H for grep is non-POSIX but all of Busybox, GNU, macOS, and
|
|
# OpenBSD support it.
|
|
method_const() {
|
|
# NOTE: File ./internal/remotekv/rediskv/rediskv.go is excluded, since it
|
|
# uses "GET" as a Redis command.
|
|
find . \
|
|
-type 'f' \
|
|
'(' -name '*.go' '!' -path './internal/remotekv/rediskv/rediskv.go' ')' \
|
|
-exec \
|
|
'grep' \
|
|
'-H' \
|
|
'-e' '"DELETE"' \
|
|
'-e' '"GET"' \
|
|
'-e' '"PATCH"' \
|
|
'-e' '"POST"' \
|
|
'-e' '"PUT"' \
|
|
'-n' \
|
|
'{}' \
|
|
';'
|
|
}
|
|
|
|
# underscores is a simple check against Go filenames with underscores. Add new
|
|
# build tags and OS as you go. The main goal of this check is to discourage the
|
|
# use of filenames like client_manager.go.
|
|
underscores() {
|
|
underscore_files="$(
|
|
find . \
|
|
-type 'f' \
|
|
-name '*_*.go' \
|
|
'!' '(' -name '*_darwin.go' \
|
|
-o -name '*_generate.go' \
|
|
-o -name '*_grpc.pb.go' \
|
|
-o -name '*_linux.go' \
|
|
-o -name '*_noreuseport.go' \
|
|
-o -name '*_others.go' \
|
|
-o -name '*_reuseport.go' \
|
|
-o -name '*_test.go' \
|
|
-o -name '*_unix.go' \
|
|
-o -name '*_windows.go' \
|
|
')' \
|
|
-exec 'printf' '\t%s\n' '{}' ';'
|
|
)"
|
|
readonly underscore_files
|
|
|
|
if [ "$underscore_files" != '' ]; then
|
|
printf \
|
|
'found file names with underscores:\n%s\n' \
|
|
"$underscore_files"
|
|
fi
|
|
}
|
|
|
|
# TODO(a.garipov): Add an analyzer to look for `fallthrough`, `goto`, and `new`?
|
|
|
|
# Checks
|
|
|
|
# TODO(a.garipov): Remove the dnsserver stuff once it is separated.
|
|
dnssrvmod='github.com/AdguardTeam/AdGuardDNS/internal/dnsserver/...'
|
|
readonly dnssrvmod
|
|
|
|
run_linter -e blocklist_imports
|
|
|
|
run_linter -e method_const
|
|
|
|
run_linter -e underscores
|
|
|
|
run_linter -e gofumpt --extra -e -l .
|
|
|
|
run_linter "${GO:-go}" vet ./... "$dnssrvmod"
|
|
|
|
run_linter govulncheck ./... "$dnssrvmod"
|
|
|
|
# NOTE: For AdGuard DNS, ignore the generated protobuf files.
|
|
run_linter gocyclo --ignore '\.pb\.go$' --over 10 .
|
|
|
|
# NOTE: For AdGuard DNS, ignore the generated protobuf files.
|
|
run_linter gocognit --ignore '\.pb\.go$' --over 10 .
|
|
|
|
run_linter ineffassign ./... "$dnssrvmod"
|
|
|
|
run_linter unparam ./... "$dnssrvmod"
|
|
|
|
find . \
|
|
-type 'f' \
|
|
'(' \
|
|
-name 'Makefile' \
|
|
-o -name '*.conf' \
|
|
-o -name '*.go' \
|
|
-o -name '*.mod' \
|
|
-o -name '*.sh' \
|
|
-o -name '*.yaml' \
|
|
-o -name '*.yml' \
|
|
')' \
|
|
-exec 'misspell' '--error' '{}' '+'
|
|
|
|
run_linter nilness ./... "$dnssrvmod"
|
|
|
|
# TODO(a.garipov): Remove the grep crutch once golang/go#60509 is fixed.
|
|
#
|
|
# TODO(a.garipov): Add a filtering function to run_linter.
|
|
fieldalignment_output="$(
|
|
fieldalignment ./... "$dnssrvmod" 2>&1 \
|
|
| grep -e '\.pb\.go' -v \
|
|
|| :
|
|
)"
|
|
readonly fieldalignment_output
|
|
|
|
if [ "$fieldalignment_output" != '' ]; then
|
|
printf '%s\n' "$fieldalignment_output"
|
|
|
|
exit 1
|
|
fi
|
|
|
|
# TODO(a.garipov): Remove the grep crutch once golang/go#61574 is fixed.
|
|
shadow_output="$(
|
|
shadow --strict ./... "$dnssrvmod" 2>&1 \
|
|
| grep -e '\.pb\.go' -v \
|
|
|| :
|
|
)"
|
|
readonly shadow_output
|
|
|
|
if [ "$shadow_output" != '' ]; then
|
|
printf '%s\n' "$shadow_output"
|
|
|
|
exit 1
|
|
fi
|
|
|
|
run_linter gosec --quiet ./... "$dnssrvmod"
|
|
|
|
run_linter errcheck ./... "$dnssrvmod"
|
|
|
|
staticcheck_matrix='
|
|
darwin: GOOS=darwin
|
|
linux: GOOS=linux
|
|
'
|
|
readonly staticcheck_matrix
|
|
|
|
printf '%s' "$staticcheck_matrix" \
|
|
| run_linter staticcheck --matrix ./... "$dnssrvmod"
|