aboutsummaryrefslogtreecommitdiffstats
path: root/commands/msgview/save_test.go
diff options
context:
space:
mode:
authorMoritz Poldrack <git@moritz.sh>2023-06-17 16:46:31 +0200
committerRobin Jarry <robin@jarry.cc>2023-06-17 23:19:24 +0200
commit8ec2f0c1e59286f05de63b683f7316a7a40e7b46 (patch)
treea1a2157e15c1623e4b03363ed9496c741f9e8abf /commands/msgview/save_test.go
parentb13c45797a1ea2d27f162c0fde0b640d7b24471e (diff)
downloadaerc-8ec2f0c1e59286f05de63b683f7316a7a40e7b46.tar.gz
save: fix saving of multiple files with the same name
When an email has multiple attachments with the same name, aerc currently only saves one of them. This patch adds a counter to them. the file has an extension, the counter is added before the extension. Signed-off-by: Moritz Poldrack <git@moritz.sh> Acked-by: Koni Marti <koni.marti@gmail.com>
Diffstat (limited to 'commands/msgview/save_test.go')
-rw-r--r--commands/msgview/save_test.go24
1 files changed, 24 insertions, 0 deletions
diff --git a/commands/msgview/save_test.go b/commands/msgview/save_test.go
new file mode 100644
index 00000000..d6b7e757
--- /dev/null
+++ b/commands/msgview/save_test.go
@@ -0,0 +1,24 @@
+package msgview
+
+import "testing"
+
+func TestGetCollisionlessFilename(t *testing.T) {
+ tests := []struct {
+ originalFilename string
+ expectedNewName string
+ existingFiles map[string]struct{}
+ }{
+ {"test", "test", map[string]struct{}{}},
+ {"test", "test", map[string]struct{}{"other-file": {}}},
+ {"test.txt", "test.txt", map[string]struct{}{"test.log": {}}},
+ {"test.txt", "test_1.txt", map[string]struct{}{"test.txt": {}}},
+ {"test.txt", "test_2.txt", map[string]struct{}{"test.txt": {}, "test_1.txt": {}}},
+ {"test.txt", "test_1.txt", map[string]struct{}{"test.txt": {}, "test_2.txt": {}}},
+ }
+ for _, tt := range tests {
+ actual := getCollisionlessFilename(tt.originalFilename, tt.existingFiles)
+ if actual != tt.expectedNewName {
+ t.Errorf("expected %s, actual %s", tt.expectedNewName, actual)
+ }
+ }
+}