From 442c185320f3ca4d21798b3c34d7dceba63ed94b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ren=C3=A9=20=27Necoro=27=20Neumann?= Date: Sat, 22 Aug 2020 20:41:11 +0200 Subject: [PATCH] #151 Testcase for atom author in RSS --- ...author_-_rss_channel_item_author_atom.json | 33 +++++++++++++++++++ ..._author_-_rss_channel_item_author_atom.xml | 10 ++++++ translator_test.go | 11 ++++++- 3 files changed, 53 insertions(+), 1 deletion(-) create mode 100644 testdata/translator/rss/feed_item_author_-_rss_channel_item_author_atom.json create mode 100644 testdata/translator/rss/feed_item_author_-_rss_channel_item_author_atom.xml diff --git a/testdata/translator/rss/feed_item_author_-_rss_channel_item_author_atom.json b/testdata/translator/rss/feed_item_author_-_rss_channel_item_author_atom.json new file mode 100644 index 00000000..ff2dbe5a --- /dev/null +++ b/testdata/translator/rss/feed_item_author_-_rss_channel_item_author_atom.json @@ -0,0 +1,33 @@ +{ + "items": [ + { + "author": { + "name": "Item Author" + }, + "authors": [ + { + "name": "Item Author" + } + ], + "extensions": { + "atom": { + "author": [ + { + "name": "author", + "value": "", + "parsed": { + "authors": [ + { + "name": "Item Author" + } + ] + } + } + ] + } + } + } + ], + "feedType": "rss", + "feedVersion": "2.0" +} diff --git a/testdata/translator/rss/feed_item_author_-_rss_channel_item_author_atom.xml b/testdata/translator/rss/feed_item_author_-_rss_channel_item_author_atom.xml new file mode 100644 index 00000000..f444b0cc --- /dev/null +++ b/testdata/translator/rss/feed_item_author_-_rss_channel_item_author_atom.xml @@ -0,0 +1,10 @@ + + + + + Item Author + + + diff --git a/translator_test.go b/translator_test.go index 42af894d..49b3f1f8 100644 --- a/translator_test.go +++ b/translator_test.go @@ -31,9 +31,18 @@ func TestDefaultRSSTranslator_Translate(t *testing.T) { // Parse actual feed translator := &gofeed.DefaultRSSTranslator{} fp := &rss.Parser{} - rssFeed, _ := fp.Parse(f) + rssFeed, _ := fp.Parse(f, gofeed.NewParser().BuildRSSExtParsers()) actual, _ := translator.Translate(rssFeed) + // the `Parsed` part of extensions is not correctly unmarshalled from JSON + // workaround: move the actual extensions through a round of json marshalling so that we get the same + for _, i := range actual.Items { + if len(i.Extensions) > 0 { + b, _ := jsonEncoding.Marshal(i.Extensions) + jsonEncoding.Unmarshal(b, &i.Extensions) + } + } + // Get json encoded expected feed result ef := fmt.Sprintf("testdata/translator/rss/%s.json", name) e, _ := os.ReadFile(ef)