-
Notifications
You must be signed in to change notification settings - Fork 155
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
GitLab CI: hack to deal with GHC heisenbug
Every now and then, GHC will exit with the error ``` out: mmap 131072 bytes at (nil): Cannot allocate memory out: Try specifying an address with +RTS -xm<addr> -RTS out: internal error: m32_allocator_init: Failed to map (GHC version 9.0.2 for x86_64_unknown_linux) Please report this as a GHC bug: https://www.haskell.org/ghc/reportabug ``` (when the binary is named `out`). For some reason this problem has become more pronounced for us. Since we invoke GHC/Clash an awful amount of times in some of our CI tests, the chances of hitting it in one of those invocations are really high. This commit wraps the `ghc`, `ghci`, `clash` and `clashi` binaries in a Bash script that will retry for a total of three times when this error message is observed. It seems reasonable to think that the odds of it failing three times in a row are very small. However, the test suite also compiles Haskell code to a binary and then runs that binary. These binaries have the same issues, but they don't come from the PATH, so we can't intercept them like we can for things that are on the PATH. For this, we introduce a new Tasty test provider that also tries up to three times when the heisenbug's error message is observed. We need both solutions because we are also seeing the problem on `doctests` wich don't involve our Tasty test providers, so these need to be covered by the script approach. Any `clash` invocations from Tasty are not retried since the Bash script already does that. We think this problem occurs on every combination of GHC version and Linux kernel version, but we are seeing it (almost?) exclusively on GHC 9.0.2.
1 parent
4791875
commit d4338a9
Showing
8 changed files
with
168 additions
and
9 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
script |
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 @@ | ||
script |
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 @@ | ||
script |
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 @@ | ||
script |
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,61 @@ | ||
#!/bin/bash | ||
|
||
# Every now and then, GHC will exit with the error | ||
# | ||
# out: mmap 131072 bytes at (nil): Cannot allocate memory | ||
# out: Try specifying an address with +RTS -xm<addr> -RTS | ||
# out: internal error: m32_allocator_init: Failed to map | ||
# (GHC version 9.0.2 for x86_64_unknown_linux) | ||
# Please report this as a GHC bug: https://www.haskell.org/ghc/reportabug | ||
# | ||
# (when the binary is named `out`). | ||
# | ||
# Since we invoke GHC/Clash an awful amount of times in some of our CI tests, | ||
# the chances of hitting it in one of those invocations are really high. This | ||
# script wraps the relevant binaries and will retry for a total of three times | ||
# when this error message is observed. It seems reasonable to think that the | ||
# odds of it failing three times in a row are very small. | ||
# | ||
# The mmap error message itself will not be observed in stdout and stderr of | ||
# this script, but anything printed before that by the wrapped binary will | ||
# occur multiple times as the binary is run again. Given that we usually test | ||
# either that stdout or stderr is empty or that it contains or does not | ||
# contain a certain string, duplication does not affect the outcome of the | ||
# test. | ||
# | ||
# We think this problem occurs on every combination of GHC version and | ||
# Linux kernel version, but we are seeing it on (almost?) exclusively on | ||
# GHC 9.0.2. | ||
|
||
PROG="$(basename $0)" | ||
|
||
if [[ -n "$RETRY_GHC_HEISENBUG_LOOP_DETECT" ]]; then | ||
echo "retry-ghc-heisenbug: Loop detected, aborting" >&2 | ||
exit 1 | ||
fi | ||
export RETRY_GHC_HEISENBUG_LOOP_DETECT=1 | ||
|
||
REALPROG="$(which -a $PROG | tail -n+2 | head -n1)" | ||
|
||
if [[ -z "$REALPROG" ]]; then | ||
echo "retry-ghc-heisenbug: Real $PROG not found, aborting" >&2 | ||
exit 1 | ||
fi | ||
|
||
exec 3>&1 | ||
|
||
TRIES=0 | ||
while [[ $TRIES -lt 2 ]]; do | ||
"$REALPROG" "$@" 2>&1 >&3 | \ | ||
awk ' | ||
/mmap 131072 bytes at \(nil\): Cannot allocate memory/ \ | ||
{ exit 1 } | ||
{ print }' >&2 | ||
STATUS=("${PIPESTATUS[@]}") | ||
[[ ${STATUS[1]} -eq 0 ]] && exit ${STATUS[0]} | ||
((TRIES++)) | ||
done | ||
|
||
exec 3>&- | ||
|
||
"$REALPROG" "$@" |
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