Skip to content

Commit

Permalink
Update test.sh
Browse files Browse the repository at this point in the history
  • Loading branch information
ryanfoxtyler committed Feb 5, 2025
1 parent 5f20280 commit 3976c07
Showing 1 changed file with 26 additions and 26 deletions.
52 changes: 26 additions & 26 deletions test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ set -eo pipefail
go version

# Check if Github Actions is running
if [[ ${CI} == "true" ]]; then
if [ $CI = "true" ]; then
# Enable code coverage
# export because tests run in a subprocess
export covermode="-covermode=atomic"
Expand All @@ -22,28 +22,28 @@ tags="-tags=jemalloc"

# Compile the Badger binary
pushd badger
go build -v "${tags}" .
go build -v $tags .
popd

# Run the memory intensive tests first.
manual() {
timeout="-timeout 2m"
echo "==> Running package tests for ${packages}"
echo "==> Running package tests for $packages"
set -e
for pkg in ${packages}; do
echo "===> Testing ${pkg}"
go test "${tags}" -timeout=25m "${covermode}" "${coverprofile}" -failfast -race -parallel 16 "${pkg}" && write_coverage || return 1
for pkg in $packages; do
echo "===> Testing $pkg"
go test $tags -timeout=25m $covermode $coverprofile -failfast -race -parallel 16 $pkg && write_coverage || return 1
done
echo "==> DONE package tests"

echo "==> Running manual tests"
# Run the special Truncate test.
rm -rf p
set -e
go test "${tags}" "${timeout}" "${covermode}" "${coverprofile}" -run='TestTruncateVlogNoClose$' -failfast --manual=true && write_coverage || return 1
go test $tags $timeout $covermode $coverprofile -run='TestTruncateVlogNoClose$' -failfast --manual=true && write_coverage || return 1
truncate --size=4096 p/000000.vlog
go test "${tags}" "${timeout}" "${covermode}" "${coverprofile}" -run='TestTruncateVlogNoClose2$' -failfast --manual=true && write_coverage || return 1
go test "${tags}" "${timeout}" "${covermode}" "${coverprofile}" -run='TestTruncateVlogNoClose3$' -failfast --manual=true && write_coverage || return 1
go test $tags $timeout $covermode $coverprofile -run='TestTruncateVlogNoClose2$' -failfast --manual=true && write_coverage || return 1
go test $tags $timeout $covermode $coverprofile -run='TestTruncateVlogNoClose3$' -failfast --manual=true && write_coverage || return 1
rm -rf p

# TODO(ibrahim): Let's make these tests have Manual prefix.
Expand All @@ -52,14 +52,14 @@ manual() {
# TestValueGCManaged
# TestDropPrefix
# TestDropAllManaged
go test "${tags}" "${timeout}" "${covermode}" "${coverprofile}" -failfast -run='TestBigKeyValuePairs$' --manual=true && write_coverage || return 1
go test "${tags}" "${timeout}" "${covermode}" "${coverprofile}" -failfast -run='TestPushValueLogLimit' --manual=true && write_coverage || return 1
go test "${tags}" "${timeout}" "${covermode}" "${coverprofile}" -failfast -run='TestKeyCount' --manual=true && write_coverage || return 1
go test "${tags}" "${timeout}" "${covermode}" "${coverprofile}" -failfast -run='TestIteratePrefix' --manual=true && write_coverage || return 1
go test "${tags}" "${timeout}" "${covermode}" "${coverprofile}" -failfast -run='TestIterateParallel' --manual=true && write_coverage || return 1
go test "${tags}" "${timeout}" "${covermode}" "${coverprofile}" -failfast -run='TestBigStream' --manual=true && write_coverage || return 1
go test "${tags}" "${timeout}" "${covermode}" "${coverprofile}" -failfast -run='TestGoroutineLeak' --manual=true && write_coverage || return 1
go test "${tags}" "${timeout}" "${covermode}" "${coverprofile}" -failfast -run='TestGetMore' --manual=true && write_coverage || return 1
go test $tags $timeout $covermode $coverprofile -failfast -run='TestBigKeyValuePairs$' --manual=true && write_coverage || return 1
go test $tags $timeout $covermode $coverprofile -failfast -run='TestPushValueLogLimit' --manual=true && write_coverage || return 1
go test $tags $timeout $covermode $coverprofile -failfast -run='TestKeyCount' --manual=true && write_coverage || return 1
go test $tags $timeout $covermode $coverprofile -failfast -run='TestIteratePrefix' --manual=true && write_coverage || return 1
go test $tags $timeout $covermode $coverprofile -failfast -run='TestIterateParallel' --manual=true && write_coverage || return 1
go test $tags $timeout $covermode $coverprofile -failfast -run='TestBigStream' --manual=true && write_coverage || return 1
go test $tags $timeout $covermode $coverprofile -failfast -run='TestGoroutineLeak' --manual=true && write_coverage || return 1
go test $tags $timeout $covermode $coverprofile -failfast -run='TestGetMore' --manual=true && write_coverage || return 1

echo "==> DONE manual tests"
}
Expand All @@ -69,21 +69,21 @@ root() {
# go test -timeout=25m -v -race github.com/dgraph-io/badger/v4/...

echo "==> Running root level tests."
go test "${tags}" -v -race -parallel=16 -timeout=25m -failfast "${covermode}" "${coverprofile}" . && write_coverage || return 1
go test $tags -v -race -parallel=16 -timeout=25m -failfast $covermode $coverprofile . && write_coverage || return 1
echo "==> DONE root level tests"
}

stream() {
set -eo pipefail
pushd badger
baseDir=$(mktemp -d -p .)
./badger benchmark write -s --dir="${baseDir}"/test | tee "${baseDir}"/log.txt
./badger benchmark read --dir="${baseDir}"/test --full-scan | tee --append "${baseDir}"/log.txt
./badger benchmark read --dir="${baseDir}"/test -d=30s | tee --append "${baseDir}"/log.txt
./badger stream --dir="${baseDir}"/test -o "${baseDir}/test2" | tee --append "${baseDir}"/log.txt
count=$(cat "${baseDir}/log.txt" | grep "at program end: 0 B" | wc -l)
rm -rf "${baseDir}"
if [[ ${count} -ne 4 ]]; then
./badger benchmark write -s --dir=$baseDir/test | tee $baseDir/log.txt
./badger benchmark read --dir=$baseDir/test --full-scan | tee --append $baseDir/log.txt
./badger benchmark read --dir=$baseDir/test -d=30s | tee --append $baseDir/log.txt
./badger stream --dir=$baseDir/test -o "$baseDir/test2" | tee --append $baseDir/log.txt
count=$(cat "$baseDir/log.txt" | grep "at program end: 0 B" | wc -l)
rm -rf $baseDir
if [ $count -ne 4 ]; then
echo "LEAK detected in Badger stream."
return 1
fi
Expand All @@ -93,7 +93,7 @@ stream() {
}

write_coverage() {
if [[ ${CI} == "true" ]]; then
if [[ $CI == "true" ]]; then
if [[ -f cover_tmp.out ]]; then
sed -i '1d' cover_tmp.out
cat cover_tmp.out >>cover.out && rm cover_tmp.out
Expand Down

0 comments on commit 3976c07

Please sign in to comment.