File: EventsSpec.hs

package info (click to toggle)
haskell-github 0.29-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 944 kB
  • sloc: haskell: 7,744; makefile: 3
file content (36 lines) | stat: -rw-r--r-- 1,205 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
{-# LANGUAGE OverloadedStrings #-}
module GitHub.EventsSpec where

import Data.Either        (isRight)
import Data.String        (fromString)
import Prelude ()
import Prelude.Compat
import System.Environment (lookupEnv)
import Test.Hspec         (Spec, describe, it, shouldSatisfy,
                           pendingWith)

import qualified GitHub
import GitHub.Data (Auth(..))

fromRightS :: Show a => Either a b -> b
fromRightS (Left xs) = error $ "Should be Right" ++ show xs
fromRightS (Right xs) = xs

withAuth :: (Auth -> IO ()) -> IO ()
withAuth action = do
  mtoken <- lookupEnv "GITHUB_TOKEN"
  case mtoken of
    Nothing    -> pendingWith "no GITHUB_TOKEN"
    Just token -> action (OAuth $ fromString token)

spec :: Spec
spec = do
  describe "repositoryEventsR" $ do
    it "returns non empty list of events" $ shouldSucceed $
      GitHub.repositoryEventsR "haskell-github" "github" 1
  describe "userEventsR" $ do
    it "returns non empty list of events" $ shouldSucceed $ GitHub.userEventsR "phadej" 1
  where shouldSucceed f = withAuth $ \auth -> do
          cs <- GitHub.executeRequest auth $ f
          cs `shouldSatisfy` isRight
          length (fromRightS cs) `shouldSatisfy` (> 1)