diff options
author | René 'Necoro' Neumann <necoro@necoro.eu> | 2020-05-14 23:37:35 +0200 |
---|---|---|
committer | René 'Necoro' Neumann <necoro@necoro.eu> | 2020-05-14 23:37:35 +0200 |
commit | 2a8e0cf3750d3f789bcd756e39af04f00fe0e738 (patch) | |
tree | 384fcd7c9b34de17a6e516b9e2de9c88fa11a6f1 /pkg/config/url_test.go | |
parent | 65fe5cb5c88beabf6c045f20738af71c8d0e38ec (diff) | |
download | feed2imap-go-2a8e0cf3750d3f789bcd756e39af04f00fe0e738.tar.gz feed2imap-go-2a8e0cf3750d3f789bcd756e39af04f00fe0e738.tar.bz2 feed2imap-go-2a8e0cf3750d3f789bcd756e39af04f00fe0e738.zip |
Verbose variant of 'target' in config
Diffstat (limited to 'pkg/config/url_test.go')
-rw-r--r-- | pkg/config/url_test.go | 108 |
1 files changed, 108 insertions, 0 deletions
diff --git a/pkg/config/url_test.go b/pkg/config/url_test.go new file mode 100644 index 0000000..d345690 --- /dev/null +++ b/pkg/config/url_test.go @@ -0,0 +1,108 @@ +package config + +import ( + "testing" + + "github.com/google/go-cmp/cmp" + "gopkg.in/yaml.v3" +) + +func TestUrl_Unmarshal(t *testing.T) { + + tests := []struct { + name string + inp string + url Url + wantErr bool + }{ + {name: "Empty", inp: `url: ""`, wantErr: true}, + {name: "Simple String", inp: `url: "imap://user:pass@example.net:143/INBOX"`, url: Url{ + Scheme: "imap", + User: "user", + Password: "pass", + Host: "example.net", + Port: "143", + Root: "/INBOX", + }}, + {name: "Simple String with @", inp: `url: "imaps://user@example:pass@example.net:143/INBOX"`, url: Url{ + Scheme: "imaps", + User: "user@example", + Password: "pass", + Host: "example.net", + Port: "143", + Root: "/INBOX", + }}, + {name: "Simple String with %40", inp: `url: "imap://user%40example:pass@example.net:4711/INBOX"`, url: Url{ + Scheme: "imap", + User: "user@example", + Password: "pass", + Host: "example.net", + Port: "4711", + Root: "/INBOX", + }}, + {name: "Err: Inv scheme", inp: `url: "smtp://user%40example:pass@example.net:4711/INBOX"`, wantErr: true}, + {name: "Err: No Host", inp: `url: "imap://user%40example:pass/INBOX"`, wantErr: true}, + {name: "Err: Scheme Only", inp: `url: "imap://"`, wantErr: true}, + {name: "Err: No Root", inp: `url: "imap://user:pass@example.net:143"`, wantErr: true}, + {name: "Err: No Root: Slash", inp: `url: "imap://user:pass@example.net:143/"`, wantErr: true}, + {name: "Full", inp: `url: + scheme: imap + host: example.net + user: user + password: p4ss + port: 143 + root: INBOX +`, url: Url{ + Scheme: "imap", + User: "user", + Password: "p4ss", + Host: "example.net", + Port: "143", + Root: "INBOX", + }}, + {name: "Default Port", inp: `url: + scheme: imap + host: example.net + user: user + password: p4ss + root: INBOX +`, url: Url{ + Scheme: "imap", + User: "user", + Password: "p4ss", + Host: "example.net", + Port: "143", + Root: "INBOX", + }}, + {name: "Default Scheme", inp: `url: + host: example.net + user: user + password: p4ss + port: 993 + root: INBOX +`, url: Url{ + Scheme: "imaps", + User: "user", + Password: "p4ss", + Host: "example.net", + Port: "993", + Root: "INBOX", + }}, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + var u struct { + Url Url `yaml:"url"` + } + err := yaml.Unmarshal([]byte(tt.inp), &u) + if (err != nil) != tt.wantErr { + t.Errorf("Unmarshal() error = %v, wantErr %v", err, tt.wantErr) + return + } + + if diff := cmp.Diff(u.Url, tt.url); err == nil && diff != "" { + t.Error(diff) + } + }) + } +} |