From 40e983664cb253faf9329b1fd74d47338b5345b7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fr=C3=A9d=C3=A9ric=20Guillot?= Date: Fri, 6 Nov 2020 17:11:52 -0800 Subject: [PATCH] Trim spaces around icon URLs --- reader/icon/finder.go | 2 +- reader/icon/finder_test.go | 20 +++++++++++++++++++- 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/reader/icon/finder.go b/reader/icon/finder.go index 231528d4..2a17f547 100644 --- a/reader/icon/finder.go +++ b/reader/icon/finder.go @@ -72,7 +72,7 @@ func parseDocument(websiteURL string, data io.Reader) (string, error) { for _, query := range queries { doc.Find(query).Each(func(i int, s *goquery.Selection) { if href, exists := s.Attr("href"); exists { - iconURL = href + iconURL = strings.TrimSpace(href) } }) diff --git a/reader/icon/finder_test.go b/reader/icon/finder_test.go index 5fcbaa9a..ee074119 100644 --- a/reader/icon/finder_test.go +++ b/reader/icon/finder_test.go @@ -4,7 +4,10 @@ package icon // import "miniflux.app/reader/icon" -import "testing" +import ( + "strings" + "testing" +) func TestParseImageDataURL(t *testing.T) { iconURL := "" @@ -49,3 +52,18 @@ func TestParseInvalidImageDataURL(t *testing.T) { t.Fatal(`We should detect malformed image data URL`) } } + +func TestParseDocumentWithWhitespaceIconURL(t *testing.T) { + html := `` + + iconURL, err := parseDocument("http://www.example.org/", strings.NewReader(html)) + if err != nil { + t.Fatal(err) + } + + if iconURL != "http://www.example.org/static/img/favicon.ico" { + t.Errorf(`Invalid icon URL, got %q`, iconURL) + } +}