Skip to content

Commit

Permalink
Don't strip whitespace from stdout/stderr
Browse files Browse the repository at this point in the history
  • Loading branch information
tomjaguarpaw authored and 9999years committed Sep 7, 2024
1 parent 9e70f3a commit 2a56450
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 21 deletions.
1 change: 1 addition & 0 deletions package.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ dependencies:
- stm
- transformers
- unliftio-core
- text >=2.0

library:
source-dirs: src
Expand Down
27 changes: 20 additions & 7 deletions src/System/Process/Typed/Internal.hs
Original file line number Diff line number Diff line change
Expand Up @@ -621,15 +621,28 @@ data ExitCodeException = ExitCodeException
instance Exception ExitCodeException
instance Show ExitCodeException where
show ece =
let decodeStrip = T.unpack . T.strip . TL.toStrict . TLE.decodeUtf8With lenientDecode
stdout = decodeStrip $ eceStdout ece
stderr = decodeStrip $ eceStderr ece
stdout' = if null stdout
let decode = TL.toStrict . TLE.decodeUtf8With lenientDecode

isAsciiSpace char = case char of
' ' -> True
'\t' -> True
'\n' -> True
'\r' -> True
_ -> False
isOnlyAsciiWhitespace = T.null . T.dropAround isAsciiSpace

stdout = decode $ eceStdout ece
stderr = decode $ eceStderr ece
stdout' = if isOnlyAsciiWhitespace stdout
then []
else ["\n\nStandard output:\n", stdout]
stderr' = if null stderr
else [ "\n\nStandard output:\n"
, T.unpack stdout
]
stderr' = if isOnlyAsciiWhitespace stderr
then []
else ["\n\nStandard error:\n", stderr]
else [ "\nStandard error:\n"
, T.unpack stderr
]
in concat $
[ "Received "
, show (eceExitCode ece)
Expand Down
21 changes: 7 additions & 14 deletions test/System/Process/TypedSpec.hs
Original file line number Diff line number Diff line change
Expand Up @@ -238,7 +238,7 @@ spec = do
++ "Copied OK\n"
++ "\n"
++ "Standard error:\n"
++ "Uh oh!"
++ "Uh oh!\n"

it "Show only stdout" $ do
let exitCodeException =
Expand All @@ -253,7 +253,7 @@ spec = do
++ "Raw command: show-puppy\n"
++ "\n"
++ "Standard output:\n"
++ "No puppies found???"
++ "No puppies found???\n"

it "Show only stderr" $ do
let exitCodeException =
Expand All @@ -266,17 +266,10 @@ spec = do
show exitCodeException `shouldBe`
"Received ExitFailure 1 when running\n"
++ "Raw command: show-puppy\n"
++ "\n"
++ "Standard error:\n"
++ "No puppies found???"

it "Show trims stdout/stderr" $ do
-- This keeps the `Show` output looking nice regardless of how many
-- newlines (if any) the command outputs.
--
-- This also makes sure that the `Show` output doesn't end with a
-- spurious trailing newline, making it easier to compose `Show`
-- instances together.
++ "No puppies found???\n"

it "Show does not trim stdout/stderr" $ do
let exitCodeException =
ExitCodeException
{ eceExitCode = ExitFailure 1
Expand All @@ -289,10 +282,10 @@ spec = do
++ "Raw command: detect-doggies\n"
++ "\n"
++ "Standard output:\n"
++ "puppy\n"
++ "\n\npuppy\n\n \n"
++ "\n"
++ "Standard error:\n"
++ "doggy"
++ "\t \ndoggy\n \t\n"

it "Show displays correctly with no newlines in stdout" $ do
-- Sometimes, commands don't output _any_ newlines!
Expand Down

0 comments on commit 2a56450

Please sign in to comment.