Skip to content

Commit

Permalink
*: customize the timeouts used by unit tests in Bazel Essential CI
Browse files Browse the repository at this point in the history
We manage unit tests timeouts at two levels:
1. Bazel timeout, by default [60s,300s,900s,3600s] for [small,medium,large,enormous] targets.
2. Go timeout, set to 5 seconds less than the corresponding Bazel timeout [see cockroachdb#86363].

Previously, unit tests used the same timeouts both when running in `Bazel Essential
CI` and elsewhere. As a result, enormous test targets inherited a timeout of 1 hour
from Bazel's default timeout. This is way beyond the expected time needed by any
test target in `Bazel Essential CI`. We can't change enormous targets to large ones for
two reasons:
1. `Enormous` is also used to indicate the resources needed by a test target.
2. `Enormous` test targets may still need the large timeout when running locally.

To make this possible, we needed to support setting an `attr` value to a `select`
using Buildozer. This was done in bazelbuild/buildtools#1153.

This change only affects the timeout of `enormous` test targets. It however makes it
simple to customize the timeout of other test sizes if desired in the future.

Release note: None
Epic: none
  • Loading branch information
healthy-pod committed May 2, 2023
1 parent 2924cc5 commit 449627f
Show file tree
Hide file tree
Showing 61 changed files with 234 additions and 68 deletions.
2 changes: 2 additions & 0 deletions .bazelrc
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,8 @@ test:test --test_env=TZ=
# If those values are updated, the script should be updated accordingly.
test:race --test_timeout=1200,6000,18000,72000

# CI uses a custom timeout for enormous targets.
test:use_ci_timeouts --test_timeout=60,300,900,900 --define=use_ci_timeouts=true
# CI should always run with `--config=ci` or `--config=cinolint`.
# Prefer the first to the second unless some other job will handle linting the
# same code you're building.
Expand Down
6 changes: 3 additions & 3 deletions WORKSPACE
Original file line number Diff line number Diff line change
Expand Up @@ -355,10 +355,10 @@ load(
go_repository(
name = "com_github_bazelbuild_buildtools",
importpath = "github.com/bazelbuild/buildtools",
sha256 = "a9ef5103739dfb5ed2a5b47ab1654842a89695812e4af09e57d7015a5caf97e0",
strip_prefix = "buildtools",
sha256 = "d71a889e3bc50cc8b9d42c859e15a74f7c8d10b6786f8dd82f08f2bf24e5bdc6",
strip_prefix = "bazelbuild-buildtools-b182fc4",
urls = [
"https://storage.googleapis.com/public-bazel-artifacts/gomod/github.com/bazelbuild/buildtools/v0.0.0-20200718160251-b1667ff58f71/buildtools-v0.0.0-20200718160251-b1667ff58f71.tar.gz",
"https://storage.googleapis.com/public-bazel-artifacts/gomod/github.com/bazelbuild/buildtools/v6.1.2-0-gb182fc4/bazelbuild-buildtools-v6.1.2-0-gb182fc4.tar.gz",
],
)

Expand Down
2 changes: 1 addition & 1 deletion build/bazelutil/distdir_files.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -1171,7 +1171,7 @@ DISTDIR_FILES = {
"https://storage.googleapis.com/public-bazel-artifacts/go/20230214-214430/go1.19.4.linux-arm64.tar.gz": "6bb5752483c0d145b91199e5cc1352960d926850e75864dea16282337b0d92fe",
"https://storage.googleapis.com/public-bazel-artifacts/go/20230214-214430/go1.19.4.windows-amd64.tar.gz": "0f37edf2a6663db33c8f67ee36e21a7eb391fbf35d494299f6a81a59e294f4a0",
"https://storage.googleapis.com/public-bazel-artifacts/go/20230427-165819/go1.19.8fips.linux-amd64.tar.gz": "8170fd871cb61dc771ec1f309451b31a73d5aca3410dfa9d952672ae2be4ac9e",
"https://storage.googleapis.com/public-bazel-artifacts/gomod/github.com/bazelbuild/buildtools/v0.0.0-20200718160251-b1667ff58f71/buildtools-v0.0.0-20200718160251-b1667ff58f71.tar.gz": "a9ef5103739dfb5ed2a5b47ab1654842a89695812e4af09e57d7015a5caf97e0",
"https://storage.googleapis.com/public-bazel-artifacts/gomod/github.com/bazelbuild/buildtools/v6.1.2-0-gb182fc4/bazelbuild-buildtools-v6.1.2-0-gb182fc4.tar.gz": "d71a889e3bc50cc8b9d42c859e15a74f7c8d10b6786f8dd82f08f2bf24e5bdc6",
"https://storage.googleapis.com/public-bazel-artifacts/java/railroad/rr-1.63-java8.zip": "d2791cd7a44ea5be862f33f5a9b3d40aaad9858455828ebade7007ad7113fb41",
"https://storage.googleapis.com/public-bazel-artifacts/js/node/v16.13.0/node-v16.13.0-darwin-arm64.tar.gz": "46d83fc0bd971db5050ef1b15afc44a6665dee40bd6c1cbaec23e1b40fa49e6d",
"https://storage.googleapis.com/public-bazel-artifacts/js/node/v16.13.0/node-v16.13.0-darwin-x64.tar.gz": "37e09a8cf2352f340d1204c6154058d81362fef4ec488b0197b2ce36b3f0367a",
Expand Down
2 changes: 1 addition & 1 deletion build/teamcity/cockroach/ci/tests/unit_tests_ccl_impl.sh
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,6 @@ if tc_release_branch; then
EXTRA_PARAMS=" --flaky_test_attempts=3"
fi

$(bazel info bazel-bin --config=ci)/pkg/cmd/bazci/bazci_/bazci -- test --config=cinolint -c fastbuild \
$(bazel info bazel-bin --config=ci)/pkg/cmd/bazci/bazci_/bazci -- test --config=cinolint --config=use_ci_timeouts -c fastbuild \
//pkg:ccl_tests \
--profile=/artifacts/profile.gz $EXTRA_PARAMS
2 changes: 1 addition & 1 deletion build/teamcity/cockroach/ci/tests/unit_tests_impl.sh
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,6 @@ if tc_release_branch; then
EXTRA_PARAMS=" --flaky_test_attempts=3"
fi

$(bazel info bazel-bin --config=ci)/pkg/cmd/bazci/bazci_/bazci -- test --config=cinolint -c fastbuild \
$(bazel info bazel-bin --config=ci)/pkg/cmd/bazci/bazci_/bazci -- test --config=cinolint --config=use_ci_timeouts -c fastbuild \
//pkg:small_non_ccl_tests //pkg:medium_non_ccl_tests //pkg:large_non_ccl_tests //pkg:enormous_non_ccl_tests \
--profile=/artifacts/profile.gz $EXTRA_PARAMS
7 changes: 7 additions & 0 deletions build/toolchains/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -507,3 +507,10 @@ config_setting(
},
visibility = ["//c-deps:__pkg__"],
)

config_setting(
name = "use_ci_timeouts",
values = {
"define": "use_ci_timeouts=true",
},
)
4 changes: 2 additions & 2 deletions c-deps/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -245,14 +245,14 @@ configure_make(
}),
lib_source = "@krb5//:all",
out_static_libs = LIBKRB5_LIBS,
postfix_script = ("""mkdir -p libkrb5/lib
postfix_script = """mkdir -p libkrb5/lib
cp lib/libcom_err.a libkrb5/lib
cp lib/libgssapi_krb5.a libkrb5/lib
cp lib/libkrb5.a libkrb5/lib
cp lib/libkrb5support.a libkrb5/lib
cp lib/libk5crypto.a libkrb5/lib
mkdir -p libkrb5/include/gssapi
cp include/gssapi/gssapi.h libkrb5/include/gssapi"""),
cp include/gssapi/gssapi.h libkrb5/include/gssapi""",
visibility = ["//visibility:public"],
)

Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/backupccl/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -193,7 +193,10 @@ go_test(
"tenant_backup_nemesis_test.go",
"utils_test.go",
],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = glob(["testdata/**"]) + ["//c-deps:libgeos"],
embed = [":backupccl"],
shard_count = 48,
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/benchccl/rttanalysisccl/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,10 @@ go_test(
"bench_test.go",
"multi_region_bench_test.go",
],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = glob(["testdata/**"]),
shard_count = 16,
tags = ["ccl_test"],
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/changefeedccl/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -203,7 +203,10 @@ go_test(
"testfeed_test.go",
"validations_test.go",
],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
embed = [":changefeedccl"],
shard_count = 16,
tags = ["ccl_test"],
Expand Down
4 changes: 2 additions & 2 deletions pkg/ccl/gssapiccl/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,8 @@ go_library(
name = "gssapiccl",
srcs = select({
"@io_bazel_rules_go//go/platform:linux": [
"gssapi.go",
"get_user.go",
"gssapi.go",
],
"//conditions:default": ["empty.go"],
}),
Expand All @@ -31,10 +31,10 @@ go_library(
"//pkg/security/username",
"//pkg/settings",
"//pkg/sql",
"//pkg/sql/sem/tree",
"//pkg/sql/pgwire",
"//pkg/sql/pgwire/hba",
"//pkg/sql/pgwire/identmap",
"//pkg/sql/sem/tree",
"@com_github_cockroachdb_errors//:errors",
],
"//conditions:default": [],
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/kvccl/kvtenantccl/upgradeinterlockccl/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,10 @@ go_test(
"main_test.go",
"tenant_upgrade_test.go",
],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
tags = ["ccl_test"],
deps = [
"//pkg/base",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "3node-tenant-multiregion_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/logictestccl/tests/3node-tenant/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "3node-tenant_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/logictestccl/tests/5node/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "5node_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/logictestccl/tests/fakedist-disk/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "fakedist-disk_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/logictestccl/tests/fakedist-vec-off/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "fakedist-vec-off_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/logictestccl/tests/fakedist/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "fakedist_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "local-legacy-schema-changer_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/logictestccl/tests/local-mixed-22.2-23.1/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "local-mixed-22_2-23_1_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/logictestccl/tests/local-vec-off/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "local-vec-off_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/logictestccl/tests/local/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "local_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "multiregion-15node-5region-3azs_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "multiregion-3node-3superlongregions_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "multiregion-9node-3region-3azs-no-los_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "multiregion-9node-3region-3azs-tenant_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "multiregion-9node-3region-3azs-vec-off_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ go_test(
name = "multiregion-9node-3region-3azs_test",
size = "enormous",
srcs = ["generated_test.go"],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = [
"//c-deps:libgeos", # keep
"//pkg/ccl/logictestccl:testdata", # keep
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/multiregionccl/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,10 @@ go_test(
"show_test.go",
"unique_test.go",
],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = glob(["testdata/**"]),
embed = [":multiregionccl"],
shard_count = 16,
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/schemachangerccl/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,10 @@ go_test(
":test_gen_backup_non_ccl", # keep
":test_gen_ccl", # keep
],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = glob(["testdata/**"]) + [
"//pkg/sql/schemachanger:testdata",
],
Expand Down
5 changes: 4 additions & 1 deletion pkg/ccl/serverccl/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,10 @@ go_test(
"tenant_migration_test.go",
"tenant_vars_test.go",
],
args = ["-test.timeout=3595s"],
args = select({
"//build/toolchains:use_ci_timeouts": ["-test.timeout=895s"],
"//conditions:default": ["-test.timeout=3595s"],
}),
data = glob(["testdata/**"]),
embed = [":serverccl"],
tags = ["ccl_test"],
Expand Down
Loading

0 comments on commit 449627f

Please sign in to comment.