-
Notifications
You must be signed in to change notification settings - Fork 4.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Catalog V2 Container Based Integration Test (#17674)
* Implement the Catalog V2 controller integration container tests This now allows the container tests to import things from the root module. However for now we want to be very restrictive about which packages we allow importing. * Add an upgrade test for the new catalog Currently this should be dormant and not executed. However its put in place to detect breaking changes in the future and show an example of how to do an upgrade test with integration tests structured like catalog v2. * Make testutil.Retry capable of performing cleanup operations These cleanup operations are executed after each retry attempt. * Move TestContext to taking an interface instead of a concrete testing.T This allows this to be used on a retry.R or generally anything that meets the interface. * Move to using TestContext instead of background contexts Also this forces all test methods to implement the Cleanup method now instead of that being an optional interface. Co-authored-by: Daniel Upton <daniel@floppy.co>
- Loading branch information
Showing
18 changed files
with
613 additions
and
113 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,124 @@ | ||
#!/usr/bin/env bash | ||
# Copyright (c) HashiCorp, Inc. | ||
# SPDX-License-Identifier: MPL-2.0 | ||
|
||
|
||
readonly SCRIPT_NAME="$(basename ${BASH_SOURCE[0]})" | ||
readonly SCRIPT_DIR="$(dirname "${BASH_SOURCE[0]}")" | ||
readonly SOURCE_DIR="$(dirname "$(dirname "${SCRIPT_DIR}")")" | ||
readonly FN_DIR="$(dirname "${SCRIPT_DIR}")/functions" | ||
|
||
source "${SCRIPT_DIR}/functions.sh" | ||
|
||
|
||
set -uo pipefail | ||
|
||
usage() { | ||
cat <<-EOF | ||
Usage: ${SCRIPT_NAME} <module root> [<allowed relative package path>...] | ||
Description: | ||
Verifies that only the specified packages may be imported from the given module | ||
Options: | ||
-h | --help Print this help text. | ||
EOF | ||
} | ||
|
||
function err_usage { | ||
err "$1" | ||
err "" | ||
err "$(usage)" | ||
} | ||
|
||
function main { | ||
local module_root="" | ||
declare -a allowed_packages=() | ||
while test $# -gt 0 | ||
do | ||
case "$1" in | ||
-h | --help ) | ||
usage | ||
return 0 | ||
;; | ||
* ) | ||
if test -z "$module_root" | ||
then | ||
module_root="$1" | ||
else | ||
allowed_packages+="$1" | ||
fi | ||
shift | ||
esac | ||
done | ||
|
||
# If we could guarantee this ran with bash 4.2+ then the final argument could | ||
# be just ${allowed_packages[@]}. However that with older versions of bash | ||
# in combination with set -u causes bash to emit errors about using unbound | ||
# variables when no allowed packages have been specified (i.e. the module should | ||
# generally be disallowed with no exceptions). This syntax is very strange | ||
# but seems to be the prescribed workaround I found. | ||
check_imports "$module_root" ${allowed_packages[@]+"${allowed_packages[@]}"} | ||
return $? | ||
} | ||
|
||
function check_imports { | ||
local module_root="$1" | ||
shift | ||
local allowed_packages="$@" | ||
|
||
module_imports=$( go list -test -f '{{join .TestImports "\n"}}' ./... | grep "$module_root" | sort | uniq) | ||
module_test_imports=$( go list -test -f '{{join .TestImports "\n"}}' ./... | grep "$module_root" | sort | uniq) | ||
|
||
any_error=0 | ||
|
||
for imp in $module_imports | ||
do | ||
is_import_allowed "$imp" "$module_root" $allowed_packages | ||
allowed=$? | ||
|
||
if test $any_error -ne 1 | ||
then | ||
any_error=$allowed | ||
fi | ||
done | ||
|
||
if test $any_error -eq 1 | ||
then | ||
echo "Only the following direct imports are allowed from module $module_root:" | ||
for pkg in $allowed_packages | ||
do | ||
echo " * $pkg" | ||
done | ||
fi | ||
|
||
return $any_error | ||
} | ||
|
||
function is_import_allowed { | ||
local pkg_import=$1 | ||
shift | ||
local module_root=$1 | ||
shift | ||
local allowed_packages="$@" | ||
|
||
# check if the import path is a part of the module we are restricting imports for | ||
if test "$( go list -f '{{.Module.Path}}' $pkg_import)" != "$module_root" | ||
then | ||
return 0 | ||
fi | ||
|
||
for pkg in $allowed_packages | ||
do | ||
if test "${module_root}/$pkg" == "$pkg_import" | ||
then | ||
return 0 | ||
fi | ||
done | ||
|
||
err "Import of package $pkg_import is not allowed" | ||
return 1 | ||
} | ||
|
||
main "$@" | ||
exit $? |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.