Fix test suite failure on Windows
It would be better if the Arbitrary instance avoided generating impossible filenames like "foo/c:bar", but proably this is the only place that splits the file from the directory and then uses the file without the directory.. At least on the quickcheck properties. Sponsored-by: Svenne Krap on Patreon
This commit is contained in:
parent
f9b92c81f6
commit
4ed36b2634
4 changed files with 38 additions and 2 deletions
|
@ -36,7 +36,7 @@ type MkViewedFile = FilePath -> ViewedFile
|
||||||
- So, from dir/subdir/file.foo, generate file_%dir%subdir%.foo
|
- So, from dir/subdir/file.foo, generate file_%dir%subdir%.foo
|
||||||
-}
|
-}
|
||||||
viewedFileFromReference :: MkViewedFile
|
viewedFileFromReference :: MkViewedFile
|
||||||
viewedFileFromReference f = concat
|
viewedFileFromReference f = concat $
|
||||||
[ escape (fromRawFilePath base)
|
[ escape (fromRawFilePath base)
|
||||||
, if null dirs then "" else "_%" ++ intercalate "%" (map escape dirs) ++ "%"
|
, if null dirs then "" else "_%" ++ intercalate "%" (map escape dirs) ++ "%"
|
||||||
, escape $ fromRawFilePath $ S.concat extensions
|
, escape $ fromRawFilePath $ S.concat extensions
|
||||||
|
@ -44,7 +44,13 @@ viewedFileFromReference f = concat
|
||||||
where
|
where
|
||||||
(path, basefile) = splitFileName f
|
(path, basefile) = splitFileName f
|
||||||
dirs = filter (/= ".") $ map dropTrailingPathSeparator (splitPath path)
|
dirs = filter (/= ".") $ map dropTrailingPathSeparator (splitPath path)
|
||||||
(base, extensions) = splitShortExtensions (toRawFilePath basefile)
|
(base, extensions) = splitShortExtensions (toRawFilePath basefile')
|
||||||
|
|
||||||
|
{- On Windows, if the filename looked like "dir/c:foo" then
|
||||||
|
- basefile would look like it contains a drive letter, which will
|
||||||
|
- not work. There cannot really be a filename like that, probably,
|
||||||
|
- but it prevents the test suite failing. -}
|
||||||
|
(_basedrive, basefile') = splitDrive basefile
|
||||||
|
|
||||||
{- To avoid collisions with filenames or directories that contain
|
{- To avoid collisions with filenames or directories that contain
|
||||||
- '%', and to allow the original directories to be extracted
|
- '%', and to allow the original directories to be extracted
|
||||||
|
|
|
@ -14,6 +14,7 @@ git-annex (8.20210804) UNRELEASED; urgency=medium
|
||||||
on other OS's (except for adb, external, gcrypt, hook, and rsync).
|
on other OS's (except for adb, external, gcrypt, hook, and rsync).
|
||||||
* unused: Skip the refs/annex/last-index ref that git-annex recently
|
* unused: Skip the refs/annex/last-index ref that git-annex recently
|
||||||
started creating.
|
started creating.
|
||||||
|
* Fix test suite failure on Windows.
|
||||||
|
|
||||||
-- Joey Hess <id@joeyh.name> Tue, 03 Aug 2021 12:22:45 -0400
|
-- Joey Hess <id@joeyh.name> Tue, 03 Aug 2021 12:22:45 -0400
|
||||||
|
|
||||||
|
|
|
@ -96,3 +96,5 @@ Windows version 21H1 (build 19043.1165), 64 bit.
|
||||||
### Have you had any luck using git-annex before? (Sometimes we get tired of reading bug reports all day and a lil' positive end note does wonders)
|
### Have you had any luck using git-annex before? (Sometimes we get tired of reading bug reports all day and a lil' positive end note does wonders)
|
||||||
|
|
||||||
Git Annex is great. It works with multi-gigabyte backup files (largest around 180GB) via the BLAKE2B160E backend just dandy :)
|
Git Annex is great. It works with multi-gigabyte backup files (largest around 180GB) via the BLAKE2B160E backend just dandy :)
|
||||||
|
|
||||||
|
> [[fixed|done]] --[[Joey]]
|
||||||
|
|
|
@ -0,0 +1,27 @@
|
||||||
|
[[!comment format=mdwn
|
||||||
|
username="joey"
|
||||||
|
subject="""comment 1"""
|
||||||
|
date="2021-08-24T17:01:01Z"
|
||||||
|
content="""
|
||||||
|
I fixed the other, similar bug shortly after you filed it. Please do file
|
||||||
|
bug reports for intermittent test suite breakage like this.
|
||||||
|
|
||||||
|
This does not reproduce on linux with --quickcheck-replay=258328, it's
|
||||||
|
windows specific. I can reproduce it by subbing in the windows filepath
|
||||||
|
modules on linux.
|
||||||
|
|
||||||
|
Simplified:
|
||||||
|
|
||||||
|
ghci> let f = AssociatedFile (Just "foo\\X:l")
|
||||||
|
ghci> let m = MetaData (fromList [(MetaField "H",S.fromList [MetaValue (CurrentlySet True) ">"]),(MetaField "HJ",S.fromList [MetaValue (CurrentlySet True) "a"]),(MetaField "m",S.fromList [MetaValue (CurrentlySet True) "#"]),(MetaField "ub",S.fromList [MetaValue (CurrentlySet True) "9"])])
|
||||||
|
ghci> prop_view_roundtrips f m True
|
||||||
|
False
|
||||||
|
|
||||||
|
Looks like viewedFileFromReference of that filename produces "X:l_%\\\\%",
|
||||||
|
which won't work because that looks like a drive letter.
|
||||||
|
|
||||||
|
This can't occur in real life, because "X:l" can't be the name of a file
|
||||||
|
in a directory "foo".
|
||||||
|
|
||||||
|
Fixed.
|
||||||
|
"""]]
|
Loading…
Reference in a new issue