cmd/gitannex: Repeat TestEndToEnd for all layout modes

I'm hopeful that running these in parallel will not impact CI runtime
very much, but that likely depends on the number of CPU cores and
whether the tmp filesystem is backed by memory vs a physical disk.

Issue #7625
This commit is contained in:
Dan McArdle 2024-04-11 10:47:03 -04:00 committed by Nick Craig-Wood
parent 9a2b85d71c
commit 4ab235c06c

View file

@ -220,12 +220,17 @@ func skipE2eTestIfNecessary(t *testing.T) {
func TestEndToEnd(t *testing.T) { func TestEndToEnd(t *testing.T) {
skipE2eTestIfNecessary(t) skipE2eTestIfNecessary(t)
for _, mode := range allLayoutModes() {
mode := mode
t.Run(string(mode), func(t *testing.T) {
t.Parallel()
// Create a temp directory and chdir there, just in case. // Create a temp directory and chdir there, just in case.
originalWd, err := os.Getwd() originalWd, err := os.Getwd()
require.NoError(t, err) require.NoError(t, err)
tempDir := t.TempDir() tempDir := t.TempDir()
require.NoError(t, os.Chdir(tempDir)) require.NoError(t, os.Chdir(tempDir))
defer func() { require.NoError(t, os.Chdir(originalWd)) }() t.Cleanup(func() { require.NoError(t, os.Chdir(originalWd)) })
testingContext := makeE2eTestingContext(t) testingContext := makeE2eTestingContext(t)
testingContext.installRcloneGitannexSymlink(t) testingContext.installRcloneGitannexSymlink(t)
@ -234,9 +239,12 @@ func TestEndToEnd(t *testing.T) {
testingContext.runInRepo(t, "git", "annex", "initremote", "MyTestRemote", testingContext.runInRepo(t, "git", "annex", "initremote", "MyTestRemote",
"type=external", "externaltype=rclone-builtin", "encryption=none", "type=external", "externaltype=rclone-builtin", "encryption=none",
"rcloneremotename=MyRcloneRemote", "rcloneprefix="+testingContext.ephemeralRepoDir) "rcloneremotename=MyRcloneRemote", "rcloneprefix="+testingContext.ephemeralRepoDir,
"rclonelayout="+string(mode))
testingContext.runInRepo(t, "git", "annex", "testremote", "MyTestRemote") testingContext.runInRepo(t, "git", "annex", "testremote", "MyTestRemote")
})
}
} }
// For each layout mode, ensure that we're compatible with data written by // For each layout mode, ensure that we're compatible with data written by