aboutsummaryrefslogtreecommitdiffhomepage
path: root/reader
diff options
context:
space:
mode:
authorGravatar Frédéric Guillot <fred@miniflux.net>2019-03-26 19:49:59 -0700
committerGravatar fguillot <fred@miniflux.net>2019-03-26 20:09:31 -0700
commit129f1bf3da188756c8c2ab6c894457e55987af5a (patch)
treead6acd274e1b67f03fa4f8f5ec2699e06cbe3790 /reader
parent304b43cb308f326e2a5a5cda6fa886906b6c4f83 (diff)
Add support for OPML v1 import
Diffstat (limited to 'reader')
-rw-r--r--reader/opml/opml.go12
-rw-r--r--reader/opml/parser_test.go71
2 files changed, 76 insertions, 7 deletions
diff --git a/reader/opml/opml.go b/reader/opml/opml.go
index 27d0167..76d6193 100644
--- a/reader/opml/opml.go
+++ b/reader/opml/opml.go
@@ -4,7 +4,9 @@
package opml // import "miniflux.app/reader/opml"
-import "encoding/xml"
+import (
+ "encoding/xml"
+)
type opml struct {
XMLName xml.Name `xml:"opml"`
@@ -48,10 +50,6 @@ func (o *outline) GetSiteURL() string {
return o.FeedURL
}
-func (o *outline) IsCategory() bool {
- return o.Text != "" && o.SiteURL == "" && o.FeedURL == ""
-}
-
func (o *outline) Append(subscriptions SubcriptionList, category string) SubcriptionList {
if o.FeedURL != "" {
subscriptions = append(subscriptions, &Subcription{
@@ -67,10 +65,10 @@ func (o *outline) Append(subscriptions SubcriptionList, category string) Subcrip
func (o *opml) Transform() SubcriptionList {
var subscriptions SubcriptionList
-
for _, outline := range o.Outlines {
- if outline.IsCategory() {
+ if len(outline.Outlines) > 0 {
for _, element := range outline.Outlines {
+ // outline.Text is only available in OPML v2.
subscriptions = element.Append(subscriptions, outline.Text)
}
} else {
diff --git a/reader/opml/parser_test.go b/reader/opml/parser_test.go
index ef8e9f1..f6ce634 100644
--- a/reader/opml/parser_test.go
+++ b/reader/opml/parser_test.go
@@ -122,6 +122,77 @@ func TestParseOpmlWithEmptyTitleAndEmptySiteURL(t *testing.T) {
}
}
+func TestParseOpmlVersion1(t *testing.T) {
+ data := `<?xml version="1.0"?>
+ <opml version="1.0">
+ <head>
+ <title>mySubscriptions.opml</title>
+ <dateCreated>Wed, 13 Mar 2019 11:51:41 GMT</dateCreated>
+ </head>
+ <body>
+ <outline title="Feed 1">
+ <outline type="rss" title="Feed 1" xmlUrl="http://example.org/feed1/" htmlUrl="http://example.org/1"></outline>
+ </outline>
+ <outline title="Feed 2">
+ <outline type="rss" title="Feed 2" xmlUrl="http://example.org/feed2/" htmlUrl="http://example.org/2"></outline>
+ </outline>
+ </body>
+ </opml>
+ `
+
+ var expected SubcriptionList
+ expected = append(expected, &Subcription{Title: "Feed 1", FeedURL: "http://example.org/feed1/", SiteURL: "http://example.org/1", CategoryName: ""})
+ expected = append(expected, &Subcription{Title: "Feed 2", FeedURL: "http://example.org/feed2/", SiteURL: "http://example.org/2", CategoryName: ""})
+
+ subscriptions, err := Parse(bytes.NewBufferString(data))
+ if err != nil {
+ t.Error(err)
+ }
+
+ if len(subscriptions) != 2 {
+ t.Errorf("Wrong number of subscriptions: %d instead of %d", len(subscriptions), 2)
+ }
+
+ for i := 0; i < len(subscriptions); i++ {
+ if !subscriptions[i].Equals(expected[i]) {
+ t.Errorf(`Subscription are different: "%v" vs "%v"`, subscriptions[i], expected[i])
+ }
+ }
+}
+
+func TestParseOpmlVersion1WithoutOuterOutline(t *testing.T) {
+ data := `<?xml version="1.0"?>
+ <opml version="1.0">
+ <head>
+ <title>mySubscriptions.opml</title>
+ <dateCreated>Wed, 13 Mar 2019 11:51:41 GMT</dateCreated>
+ </head>
+ <body>
+ <outline type="rss" title="Feed 1" xmlUrl="http://example.org/feed1/" htmlUrl="http://example.org/1"></outline>
+ <outline type="rss" title="Feed 2" xmlUrl="http://example.org/feed2/" htmlUrl="http://example.org/2"></outline>
+ </body>
+ </opml>
+ `
+
+ var expected SubcriptionList
+ expected = append(expected, &Subcription{Title: "Feed 1", FeedURL: "http://example.org/feed1/", SiteURL: "http://example.org/1", CategoryName: ""})
+ expected = append(expected, &Subcription{Title: "Feed 2", FeedURL: "http://example.org/feed2/", SiteURL: "http://example.org/2", CategoryName: ""})
+
+ subscriptions, err := Parse(bytes.NewBufferString(data))
+ if err != nil {
+ t.Error(err)
+ }
+
+ if len(subscriptions) != 2 {
+ t.Errorf("Wrong number of subscriptions: %d instead of %d", len(subscriptions), 2)
+ }
+
+ for i := 0; i < len(subscriptions); i++ {
+ if !subscriptions[i].Equals(expected[i]) {
+ t.Errorf(`Subscription are different: "%v" vs "%v"`, subscriptions[i], expected[i])
+ }
+ }
+}
func TestParseInvalidXML(t *testing.T) {
data := `garbage`
_, err := Parse(bytes.NewBufferString(data))