diff options
author | Evgeny Kuznetsov <evgeny@kuznetsov.md> | 2020-01-28 20:50:24 +0300 |
---|---|---|
committer | Evgeny Kuznetsov <evgeny@kuznetsov.md> | 2020-01-28 20:50:24 +0300 |
commit | 60d88d0bc841b1b48fd2a5262dc6723d63e4d641 (patch) | |
tree | 3ef60f15b8b83e339deecee35bf798d273f73d78 | |
parent | c13ee4fe746f4ba5fd48f926f3315284e66193f3 (diff) | |
download | radiorus-rss-60d88d0bc841b1b48fd2a5262dc6723d63e4d641.tar.gz radiorus-rss-60d88d0bc841b1b48fd2a5262dc6723d63e4d641.zip |
improve test coverage
-rw-r--r-- | main_test.go | 29 |
1 files changed, 28 insertions, 1 deletions
diff --git a/main_test.go b/main_test.go index fab7129..f24880c 100644 --- a/main_test.go +++ b/main_test.go @@ -20,10 +20,13 @@ import ( "flag" "fmt" "io/ioutil" + "log" "net/http" "net/http/httptest" "os" "path/filepath" + "strings" + "sync" "testing" "github.com/gorilla/feeds" @@ -74,6 +77,30 @@ func TestFeed(t *testing.T) { } } +func TestMissingEpisode(t *testing.T) { + server := helperMockServer(t) + defer helperCleanupServer(t) + + item := feeds.Item{ + Id: "aabb", + Link: &feeds.Link{Href: fmt.Sprintf("%s/brand/none", server.URL)}, + } + + var buf bytes.Buffer + log.SetOutput(&buf) + defer func() { log.SetOutput(os.Stderr) }() + + var wg sync.WaitGroup + wg.Add(1) + describeEpisode(&item, &wg) + + got := string(buf.Bytes()) + want := fmt.Sprintf("could not find episode description on page %v: %v", item.Link.Href, errCantParse) + if !strings.Contains(got, want) { + t.Fatalf("got %v, want %v", got, want) + } +} + func TestServedFeed(t *testing.T) { server := helperMockServer(t) defer helperCleanupServer(t) @@ -135,6 +162,6 @@ func TestEpisodeURLPrefix(t *testing.T) { want := "http://www.radiorus.ru/brand/" if got != want { - t.Fatal(fmt.Sprintf("got %v, want %v", got, want)) + t.Fatalf("got %v, want %v", got, want) } } |