Merge branch 'en/fast-import-parsing-fix'
"git fast-import" update. * en/fast-import-parsing-fix: fast-import: fix erroneous handling of get-mark with empty orphan commits fast-import: only allow cat-blob requests where it makes sense fast-import: check most prominent commands first git-fast-import.txt: fix wording about where ls command can appear t9300: demonstrate bug with get-mark and empty orphan commits
This commit is contained in:
@ -3262,4 +3262,41 @@ test_expect_success PIPE 'V: checkpoint updates tags after tag' '
|
||||
background_import_still_running
|
||||
'
|
||||
|
||||
###
|
||||
### series W (get-mark and empty orphan commits)
|
||||
###
|
||||
|
||||
cat >>W-input <<-W_INPUT_END
|
||||
commit refs/heads/W-branch
|
||||
mark :1
|
||||
author Full Name <user@company.tld> 1000000000 +0100
|
||||
committer Full Name <user@company.tld> 1000000000 +0100
|
||||
data 27
|
||||
Intentionally empty commit
|
||||
LFsget-mark :1
|
||||
W_INPUT_END
|
||||
|
||||
test_expect_success !MINGW 'W: get-mark & empty orphan commit with no newlines' '
|
||||
sed -e s/LFs// W-input | tr L "\n" | git fast-import
|
||||
'
|
||||
|
||||
test_expect_success !MINGW 'W: get-mark & empty orphan commit with one newline' '
|
||||
sed -e s/LFs/L/ W-input | tr L "\n" | git fast-import
|
||||
'
|
||||
|
||||
test_expect_success !MINGW 'W: get-mark & empty orphan commit with ugly second newline' '
|
||||
# Technically, this should fail as it has too many linefeeds
|
||||
# according to the grammar in fast-import.txt. But, for whatever
|
||||
# reason, it works. Since using the correct number of newlines
|
||||
# does not work with older (pre-2.22) versions of git, allow apps
|
||||
# that used this second-newline workaround to keep working by
|
||||
# checking it with this test...
|
||||
sed -e s/LFs/LL/ W-input | tr L "\n" | git fast-import
|
||||
'
|
||||
|
||||
test_expect_success !MINGW 'W: get-mark & empty orphan commit with erroneous third newline' '
|
||||
# ...but do NOT allow more empty lines than that (see previous test).
|
||||
sed -e s/LFs/LLL/ W-input | tr L "\n" | test_must_fail git fast-import
|
||||
'
|
||||
|
||||
test_done
|
||||
|
Reference in New Issue
Block a user