| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415 |
- // Copyright 2018 Frédéric Guillot. All rights reserved.
- // Use of this source code is governed by the Apache 2.0
- // license that can be found in the LICENSE file.
- // +build integration
- package tests
- import (
- "strings"
- "testing"
- miniflux "miniflux.app/client"
- )
- func TestCreateFeed(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- if feed.ID == 0 {
- t.Fatalf(`Invalid feed ID, got %q`, feed.ID)
- }
- }
- func TestCannotCreateDuplicatedFeed(t *testing.T) {
- client := createClient(t)
- feed, category := createFeed(t, client)
- _, err := client.CreateFeed(feed.FeedURL, category.ID)
- if err == nil {
- t.Fatal(`Duplicated feeds should not be allowed`)
- }
- }
- func TestCreateFeedWithInexistingCategory(t *testing.T) {
- client := createClient(t)
- _, err := client.CreateFeed(testFeedURL, -1)
- if err == nil {
- t.Fatal(`Feeds should not be created with inexisting category`)
- }
- }
- func TestUpdateFeedURL(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- url := "test"
- updatedFeed, err := client.UpdateFeed(feed.ID, &miniflux.FeedModification{FeedURL: &url})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.FeedURL != url {
- t.Fatalf(`Wrong FeedURL, got %q instead of %q`, updatedFeed.FeedURL, url)
- }
- url = ""
- updatedFeed, err = client.UpdateFeed(feed.ID, &miniflux.FeedModification{FeedURL: &url})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.FeedURL == "" {
- t.Fatalf(`The FeedURL should not be empty`)
- }
- }
- func TestUpdateFeedSiteURL(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- url := "test"
- updatedFeed, err := client.UpdateFeed(feed.ID, &miniflux.FeedModification{SiteURL: &url})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.SiteURL != url {
- t.Fatalf(`Wrong SiteURL, got %q instead of %q`, updatedFeed.SiteURL, url)
- }
- url = ""
- updatedFeed, err = client.UpdateFeed(feed.ID, &miniflux.FeedModification{SiteURL: &url})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.SiteURL == "" {
- t.Fatalf(`The SiteURL should not be empty`)
- }
- }
- func TestUpdateFeedTitle(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- newTitle := "My new feed"
- updatedFeed, err := client.UpdateFeed(feed.ID, &miniflux.FeedModification{Title: &newTitle})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.Title != newTitle {
- t.Fatalf(`Wrong title, got %q instead of %q`, updatedFeed.Title, newTitle)
- }
- newTitle = ""
- updatedFeed, err = client.UpdateFeed(feed.ID, &miniflux.FeedModification{Title: &newTitle})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.Title == "" {
- t.Fatalf(`The Title should not be empty`)
- }
- }
- func TestUpdateFeedCrawler(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- crawler := true
- updatedFeed, err := client.UpdateFeed(feed.ID, &miniflux.FeedModification{Crawler: &crawler})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.Crawler != crawler {
- t.Fatalf(`Wrong crawler value, got "%v" instead of "%v"`, updatedFeed.Crawler, crawler)
- }
- if updatedFeed.Title != feed.Title {
- t.Fatalf(`The titles should be the same after update`)
- }
- crawler = false
- updatedFeed, err = client.UpdateFeed(feed.ID, &miniflux.FeedModification{Crawler: &crawler})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.Crawler != crawler {
- t.Fatalf(`Wrong crawler value, got "%v" instead of "%v"`, updatedFeed.Crawler, crawler)
- }
- }
- func TestUpdateFeedScraperRules(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- scraperRules := "test"
- updatedFeed, err := client.UpdateFeed(feed.ID, &miniflux.FeedModification{ScraperRules: &scraperRules})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.ScraperRules != scraperRules {
- t.Fatalf(`Wrong ScraperRules value, got "%v" instead of "%v"`, updatedFeed.ScraperRules, scraperRules)
- }
- scraperRules = ""
- updatedFeed, err = client.UpdateFeed(feed.ID, &miniflux.FeedModification{ScraperRules: &scraperRules})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.ScraperRules != scraperRules {
- t.Fatalf(`Wrong ScraperRules value, got "%v" instead of "%v"`, updatedFeed.ScraperRules, scraperRules)
- }
- }
- func TestUpdateFeedRewriteRules(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- rewriteRules := "test"
- updatedFeed, err := client.UpdateFeed(feed.ID, &miniflux.FeedModification{RewriteRules: &rewriteRules})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.RewriteRules != rewriteRules {
- t.Fatalf(`Wrong RewriteRules value, got "%v" instead of "%v"`, updatedFeed.RewriteRules, rewriteRules)
- }
- rewriteRules = ""
- updatedFeed, err = client.UpdateFeed(feed.ID, &miniflux.FeedModification{RewriteRules: &rewriteRules})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.RewriteRules != rewriteRules {
- t.Fatalf(`Wrong RewriteRules value, got "%v" instead of "%v"`, updatedFeed.RewriteRules, rewriteRules)
- }
- }
- func TestUpdateFeedUserAgent(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- userAgent := "test"
- updatedFeed, err := client.UpdateFeed(feed.ID, &miniflux.FeedModification{UserAgent: &userAgent})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.UserAgent != userAgent {
- t.Fatalf(`Wrong UserAgent value, got "%v" instead of "%v"`, updatedFeed.UserAgent, userAgent)
- }
- userAgent = ""
- updatedFeed, err = client.UpdateFeed(feed.ID, &miniflux.FeedModification{UserAgent: &userAgent})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.UserAgent != userAgent {
- t.Fatalf(`Wrong UserAgent value, got "%v" instead of "%v"`, updatedFeed.UserAgent, userAgent)
- }
- }
- func TestUpdateFeedUsername(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- username := "test"
- updatedFeed, err := client.UpdateFeed(feed.ID, &miniflux.FeedModification{Username: &username})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.Username != username {
- t.Fatalf(`Wrong Username value, got "%v" instead of "%v"`, updatedFeed.Username, username)
- }
- username = ""
- updatedFeed, err = client.UpdateFeed(feed.ID, &miniflux.FeedModification{Username: &username})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.Username != username {
- t.Fatalf(`Wrong Username value, got "%v" instead of "%v"`, updatedFeed.Username, username)
- }
- }
- func TestUpdateFeedPassword(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- password := "test"
- updatedFeed, err := client.UpdateFeed(feed.ID, &miniflux.FeedModification{Password: &password})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.Password != password {
- t.Fatalf(`Wrong Password value, got "%v" instead of "%v"`, updatedFeed.Password, password)
- }
- password = ""
- updatedFeed, err = client.UpdateFeed(feed.ID, &miniflux.FeedModification{Password: &password})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.Password != password {
- t.Fatalf(`Wrong Password value, got "%v" instead of "%v"`, updatedFeed.Password, password)
- }
- }
- func TestUpdateFeedCategory(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- newCategory, err := client.CreateCategory("my new category")
- if err != nil {
- t.Fatal(err)
- }
- updatedFeed, err := client.UpdateFeed(feed.ID, &miniflux.FeedModification{CategoryID: &newCategory.ID})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.Category.ID != newCategory.ID {
- t.Fatalf(`Wrong CategoryID value, got "%v" instead of "%v"`, updatedFeed.Category.ID, newCategory.ID)
- }
- categoryID := int64(0)
- updatedFeed, err = client.UpdateFeed(feed.ID, &miniflux.FeedModification{CategoryID: &categoryID})
- if err != nil {
- t.Fatal(err)
- }
- if updatedFeed.Category.ID == 0 {
- t.Fatalf(`The CategoryID must defined`)
- }
- }
- func TestDeleteFeed(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- if err := client.DeleteFeed(feed.ID); err != nil {
- t.Fatal(err)
- }
- }
- func TestRefreshFeed(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- if err := client.RefreshFeed(feed.ID); err != nil {
- t.Fatal(err)
- }
- }
- func TestGetFeed(t *testing.T) {
- client := createClient(t)
- feed, category := createFeed(t, client)
- if feed.Title != testFeedTitle {
- t.Fatalf(`Invalid feed title, got "%v" instead of "%v"`, feed.Title, testFeedTitle)
- }
- if feed.SiteURL != testWebsiteURL {
- t.Fatalf(`Invalid site URL, got "%v" instead of "%v"`, feed.SiteURL, testWebsiteURL)
- }
- if feed.FeedURL != testFeedURL {
- t.Fatalf(`Invalid feed URL, got "%v" instead of "%v"`, feed.FeedURL, testFeedURL)
- }
- if feed.Category.ID != category.ID {
- t.Fatalf(`Invalid feed category ID, got "%v" instead of "%v"`, feed.Category.ID, category.ID)
- }
- if feed.Category.UserID != category.UserID {
- t.Fatalf(`Invalid feed category user ID, got "%v" instead of "%v"`, feed.Category.UserID, category.UserID)
- }
- if feed.Category.Title != category.Title {
- t.Fatalf(`Invalid feed category title, got "%v" instead of "%v"`, feed.Category.Title, category.Title)
- }
- }
- func TestGetFeedIcon(t *testing.T) {
- client := createClient(t)
- feed, _ := createFeed(t, client)
- feedIcon, err := client.FeedIcon(feed.ID)
- if err != nil {
- t.Fatal(err)
- }
- if feedIcon.ID == 0 {
- t.Fatalf(`Invalid feed icon ID, got "%v"`, feedIcon.ID)
- }
- if feedIcon.MimeType != "image/x-icon" {
- t.Fatalf(`Invalid feed icon mime type, got "%v" instead of "%v"`, feedIcon.MimeType, "image/x-icon")
- }
- if !strings.Contains(feedIcon.Data, "image/x-icon") {
- t.Fatalf(`Invalid feed icon data, got "%v"`, feedIcon.Data)
- }
- }
- func TestGetFeedIconNotFound(t *testing.T) {
- client := createClient(t)
- if _, err := client.FeedIcon(42); err == nil {
- t.Fatalf(`The feed icon should be null`)
- }
- }
- func TestGetFeeds(t *testing.T) {
- client := createClient(t)
- feed, category := createFeed(t, client)
- feeds, err := client.Feeds()
- if err != nil {
- t.Fatal(err)
- }
- if len(feeds) != 1 {
- t.Fatalf(`Invalid number of feeds`)
- }
- if feeds[0].ID != feed.ID {
- t.Fatalf(`Invalid feed ID, got "%v" instead of "%v"`, feeds[0].ID, feed.ID)
- }
- if feeds[0].Title != testFeedTitle {
- t.Fatalf(`Invalid feed title, got "%v" instead of "%v"`, feeds[0].Title, testFeedTitle)
- }
- if feeds[0].SiteURL != testWebsiteURL {
- t.Fatalf(`Invalid site URL, got "%v" instead of "%v"`, feeds[0].SiteURL, testWebsiteURL)
- }
- if feeds[0].FeedURL != testFeedURL {
- t.Fatalf(`Invalid feed URL, got "%v" instead of "%v"`, feeds[0].FeedURL, testFeedURL)
- }
- if feeds[0].Category.ID != category.ID {
- t.Fatalf(`Invalid feed category ID, got "%v" instead of "%v"`, feeds[0].Category.ID, category.ID)
- }
- if feeds[0].Category.UserID != category.UserID {
- t.Fatalf(`Invalid feed category user ID, got "%v" instead of "%v"`, feeds[0].Category.UserID, category.UserID)
- }
- if feeds[0].Category.Title != category.Title {
- t.Fatalf(`Invalid feed category title, got "%v" instead of "%v"`, feeds[0].Category.Title, category.Title)
- }
- }
|