test: Add --test-debug option
This work is supported by the NIH-funded NICEMAN (ReproNim TR&D3) project.
This commit is contained in:
parent
022c14ec02
commit
2b5e6ff20a
6 changed files with 84 additions and 4 deletions
|
@ -6,6 +6,7 @@ git-annex (10.20221105) UNRELEASED; urgency=medium
|
||||||
large repository. Instead that scan is done on demand.
|
large repository. Instead that scan is done on demand.
|
||||||
* When youtube-dl is not available in PATH, use yt-dlp instead.
|
* When youtube-dl is not available in PATH, use yt-dlp instead.
|
||||||
* Support parsing yt-dpl output to display download progress.
|
* Support parsing yt-dpl output to display download progress.
|
||||||
|
* test: Add --test-debug option.
|
||||||
|
|
||||||
-- Joey Hess <id@joeyh.name> Fri, 18 Nov 2022 12:58:06 -0400
|
-- Joey Hess <id@joeyh.name> Fri, 18 Nov 2022 12:58:06 -0400
|
||||||
|
|
||||||
|
|
6
Test.hs
6
Test.hs
|
@ -92,7 +92,7 @@ import qualified Utility.Gpg
|
||||||
|
|
||||||
optParser :: Parser TestOptions
|
optParser :: Parser TestOptions
|
||||||
optParser = TestOptions
|
optParser = TestOptions
|
||||||
<$> snd (tastyParser (tests 1 False True (TestOptions mempty False False Nothing mempty mempty)))
|
<$> snd (tastyParser (tests 1 False True (TestOptions mempty False False Nothing mempty False mempty)))
|
||||||
<*> switch
|
<*> switch
|
||||||
( long "keep-failures"
|
( long "keep-failures"
|
||||||
<> help "preserve repositories on test failure"
|
<> help "preserve repositories on test failure"
|
||||||
|
@ -111,6 +111,10 @@ optParser = TestOptions
|
||||||
<> help "run tests with a git config set"
|
<> help "run tests with a git config set"
|
||||||
<> metavar "NAME=VALUE"
|
<> metavar "NAME=VALUE"
|
||||||
))
|
))
|
||||||
|
<*> switch
|
||||||
|
( long "test-debug"
|
||||||
|
<> help "show debug messages for commands run by test suite"
|
||||||
|
)
|
||||||
<*> cmdParams "non-options are for internal use only"
|
<*> cmdParams "non-options are for internal use only"
|
||||||
where
|
where
|
||||||
parseconfigvalue s = case break (== '=') s of
|
parseconfigvalue s = case break (== '=') s of
|
||||||
|
|
|
@ -65,11 +65,20 @@ import qualified Command.Uninit
|
||||||
|
|
||||||
-- Run a process. The output and stderr is captured, and is only
|
-- Run a process. The output and stderr is captured, and is only
|
||||||
-- displayed if the process does not return the expected value.
|
-- displayed if the process does not return the expected value.
|
||||||
|
--
|
||||||
|
-- In debug mode, the output is allowed to pass through.
|
||||||
testProcess :: String -> [String] -> Maybe [(String, String)] -> (Bool -> Bool) -> String -> Assertion
|
testProcess :: String -> [String] -> Maybe [(String, String)] -> (Bool -> Bool) -> String -> Assertion
|
||||||
testProcess command params environ expectedret faildesc = do
|
testProcess command params environ expectedret faildesc = do
|
||||||
let p = (proc command params) { env = environ }
|
let p = (proc command params) { env = environ }
|
||||||
(transcript, ret) <- Utility.Process.Transcript.processTranscript' p Nothing
|
debug <- testDebug . testOptions <$> getTestMode
|
||||||
(expectedret ret) @? (faildesc ++ " failed (transcript follows)\n" ++ transcript)
|
if debug
|
||||||
|
then do
|
||||||
|
ret <- withCreateProcess p $ \_ _ _ pid ->
|
||||||
|
waitForProcess pid
|
||||||
|
(expectedret (ret == ExitSuccess)) @? (faildesc ++ " failed")
|
||||||
|
else do
|
||||||
|
(transcript, ret) <- Utility.Process.Transcript.processTranscript' p Nothing
|
||||||
|
(expectedret ret) @? (faildesc ++ " failed (transcript follows)\n" ++ transcript)
|
||||||
|
|
||||||
-- Run git. (Do not use to run git-annex as the one being tested
|
-- Run git. (Do not use to run git-annex as the one being tested
|
||||||
-- may not be in path.)
|
-- may not be in path.)
|
||||||
|
@ -98,7 +107,11 @@ git_annex_shouldfail' = git_annex'' (== False)
|
||||||
git_annex'' :: (Bool -> Bool) -> String -> [String] -> Maybe [(String, String)] -> String -> Assertion
|
git_annex'' :: (Bool -> Bool) -> String -> [String] -> Maybe [(String, String)] -> String -> Assertion
|
||||||
git_annex'' expectedret command params environ faildesc = do
|
git_annex'' expectedret command params environ faildesc = do
|
||||||
pp <- Annex.Path.programPath
|
pp <- Annex.Path.programPath
|
||||||
testProcess pp (command:params) environ expectedret faildesc
|
debug <- testDebug . testOptions <$> getTestMode
|
||||||
|
let params' = if debug
|
||||||
|
then "--debug":params
|
||||||
|
else params
|
||||||
|
testProcess pp (command:params') environ expectedret faildesc
|
||||||
|
|
||||||
{- Runs git-annex and returns its standard output. -}
|
{- Runs git-annex and returns its standard output. -}
|
||||||
git_annex_output :: String -> [String] -> IO String
|
git_annex_output :: String -> [String] -> IO String
|
||||||
|
|
|
@ -19,6 +19,7 @@ data TestOptions = TestOptions
|
||||||
, fakeSsh :: Bool
|
, fakeSsh :: Bool
|
||||||
, concurrentJobs :: Maybe Concurrency
|
, concurrentJobs :: Maybe Concurrency
|
||||||
, testGitConfig :: [(ConfigKey, ConfigValue)]
|
, testGitConfig :: [(ConfigKey, ConfigValue)]
|
||||||
|
, testDebug :: Bool
|
||||||
, internalData :: CmdParams
|
, internalData :: CmdParams
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,51 @@
|
||||||
|
[[!comment format=mdwn
|
||||||
|
username="joey"
|
||||||
|
subject="""comment 1"""
|
||||||
|
date="2022-11-28T18:11:41Z"
|
||||||
|
content="""
|
||||||
|
Seems like the test it is stuck in is "move (ssh remote)".
|
||||||
|
|
||||||
|
Is this replicable?
|
||||||
|
|
||||||
|
I wonder if `test_fs.py` is doing something that causes the problem.
|
||||||
|
There is some complexity in there. Maybe it's happening on one
|
||||||
|
particular FS.
|
||||||
|
|
||||||
|
If it happens when not run by `test_fs.py`, it would be useful to get a
|
||||||
|
debug log, because I think that seeing the P2P protocol dump would help
|
||||||
|
explain what has happened.
|
||||||
|
|
||||||
|
There was not a good way to get the test suite to output a full debug
|
||||||
|
log, so I had to implement one. With an updated build of git-annex,
|
||||||
|
you can use:
|
||||||
|
|
||||||
|
git-annex test -J1 --test-debug
|
||||||
|
|
||||||
|
Here's the expected output of that section of the test suite, when it
|
||||||
|
is working properly:
|
||||||
|
|
||||||
|
move foo [2022-11-28 14:54:11.10011679] (Utility.Process) process [390399] chat: sh ["-c","git-annex test --fakessh -- 'localhost' 'git-annex-shell '\"'\"'p2pstdio'\"'\"' '\"'\"'/home/joey/src/git-annex/.t/3/main1'\"'\"' '\"'\"'--debug'\"'\"' '\"'\"'c76e0406-38ea-413e-9fb0-56cc32847734'\"'\"' --uuid 000c7285-ec19-4c15-9c67-4dd4b7c74775'"]
|
||||||
|
[2022-11-28 14:54:11.129754519] (P2P.IO) [ThreadId 4] P2P > AUTH-SUCCESS 000c7285-ec19-4c15-9c67-4dd4b7c74775
|
||||||
|
[2022-11-28 14:54:11.130259741] (P2P.IO) [ssh connection Just 390399] [ThreadId 4] P2P < AUTH-SUCCESS 000c7285-ec19-4c15-9c67-4dd4b7c74775
|
||||||
|
[2022-11-28 14:54:11.13041388] (P2P.IO) [ssh connection Just 390399] [ThreadId 4] P2P > VERSION 1
|
||||||
|
[2022-11-28 14:54:11.130680315] (P2P.IO) [ThreadId 4] P2P < VERSION 1
|
||||||
|
[2022-11-28 14:54:11.13087982] (P2P.IO) [ThreadId 4] P2P > VERSION 1
|
||||||
|
[2022-11-28 14:54:11.131127415] (P2P.IO) [ssh connection Just 390399] [ThreadId 4] P2P < VERSION 1
|
||||||
|
[2022-11-28 14:54:11.131262307] (P2P.IO) [ssh connection Just 390399] [ThreadId 4] P2P > CHECKPRESENT SHA256E-s20--e394a389d787383843decc5d3d99b6d184ffa5fddeec23b911f9ee7fc8b9ea77
|
||||||
|
[2022-11-28 14:54:11.131679501] (P2P.IO) [ThreadId 4] P2P < CHECKPRESENT SHA256E-s20--e394a389d787383843decc5d3d99b6d184ffa5fddeec23b911f9ee7fc8b9ea77
|
||||||
|
[2022-11-28 14:54:11.132388822] (P2P.IO) [ThreadId 4] P2P > FAILURE
|
||||||
|
[2022-11-28 14:54:11.13261351] (P2P.IO) [ssh connection Just 390399] [ThreadId 4] P2P < FAILURE
|
||||||
|
(to origin...)
|
||||||
|
[2022-11-28 14:54:11.135583194] (P2P.IO) [ssh connection Just 390399] [ThreadId 4] P2P > PUT foo SHA256E-s20--e394a389d787383843decc5d3d99b6d184ffa5fddeec23b911f9ee7fc8b9ea77
|
||||||
|
[2022-11-28 14:54:11.136134981] (P2P.IO) [ThreadId 4] P2P < PUT foo SHA256E-s20--e394a389d787383843decc5d3d99b6d184ffa5fddeec23b911f9ee7fc8b9ea77
|
||||||
|
[2022-11-28 14:54:11.136824468] (P2P.IO) [ThreadId 4] P2P > PUT-FROM 0
|
||||||
|
[2022-11-28 14:54:11.137123219] (P2P.IO) [ssh connection Just 390399] [ThreadId 4] P2P < PUT-FROM 0
|
||||||
|
...
|
||||||
|
[2022-11-28 14:54:11.148194515] (P2P.IO) [ssh connection Just 390399] [ThreadId 4] P2P > DATA 20
|
||||||
|
[2022-11-28 14:54:11.148414855] (P2P.IO) [ThreadId 4] P2P < DATA 20
|
||||||
|
[2022-11-28 14:54:11.148739395] (P2P.IO) [ssh connection Just 390399] [ThreadId 4] P2P > VALID
|
||||||
|
^M100% 20 B 2 KiB/s 0s[2022-11-28 14:54:11.152428942] (P2P.IO) [ThreadId 4] P2P < VALID
|
||||||
|
...
|
||||||
|
[2022-11-28 14:54:11.177599567] (P2P.IO) [ThreadId 4] P2P > SUCCESS
|
||||||
|
[2022-11-28 14:54:11.177858296] (P2P.IO) [ssh connection Just 390399] [ThreadId 4] P2P < SUCCESS
|
||||||
|
"""]]
|
|
@ -44,6 +44,16 @@ framework. Pass --help for details about those.
|
||||||
One valid use of this is to change a git configuration to a value that
|
One valid use of this is to change a git configuration to a value that
|
||||||
is planned to be the new default in a future version of git.
|
is planned to be the new default in a future version of git.
|
||||||
|
|
||||||
|
* `--test-debug`
|
||||||
|
|
||||||
|
Normally output of commands run by the test suite is hidden, so even
|
||||||
|
when annex.debug or --debug is enabled, it will not be displayed.
|
||||||
|
This option makes the full output of commands run by the test suite be
|
||||||
|
displayed. It also makes the test suite run git-annex with --debug.
|
||||||
|
|
||||||
|
It's a good idea to use `-J1` in combinaton with this, otherwise
|
||||||
|
the output of concurrent tests will be mixed together.
|
||||||
|
|
||||||
# SEE ALSO
|
# SEE ALSO
|
||||||
|
|
||||||
[[git-annex]](1)
|
[[git-annex]](1)
|
||||||
|
|
Loading…
Reference in a new issue