File: CacheSpec.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 (53 lines) | stat: -rw-r--r-- 2,029 bytes parent folder | download
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE TemplateHaskell   #-}
module GitHub.Actions.CacheSpec where

import qualified GitHub as GH

import Prelude ()
import Prelude.Compat

import           Data.Aeson      (eitherDecodeStrict)
import           Data.ByteString (ByteString)
import           Data.FileEmbed  (embedFile)
import qualified Data.Vector     as V
import           Test.Hspec      (Spec, describe, it, shouldBe)

fromRightS :: Show a => Either a b -> b
fromRightS (Right b) = b
fromRightS (Left a) = error $ "Expected a Right and got a Left" ++ show a

spec :: Spec
spec = do
    describe "decoding cache payloads" $ do
        it "decodes cache list payload" $ do
            V.length (GH.withTotalCountItems cacheList) `shouldBe` 1
        it "decodes cache usage for repo" $ do
            GH.repositoryCacheUsageFullName repoCacheUsage `shouldBe` "python/cpython"
            GH.repositoryCacheUsageActiveCachesSizeInBytes repoCacheUsage `shouldBe` 55000268087
            GH.repositoryCacheUsageActiveCachesCount repoCacheUsage `shouldBe` 171
        it "decodes cache usage for org" $ do
            GH.organizationCacheUsageTotalActiveCachesSizeInBytes orgCacheUsage `shouldBe` 26586
            GH.organizationCacheUsageTotalActiveCachesCount orgCacheUsage `shouldBe` 1

  where
    cacheList :: GH.WithTotalCount GH.Cache
    cacheList =
        fromRightS (eitherDecodeStrict cacheListPayload)

    repoCacheUsage :: GH.RepositoryCacheUsage
    repoCacheUsage =
        fromRightS (eitherDecodeStrict repoCacheUsagePayload)

    orgCacheUsage :: GH.OrganizationCacheUsage
    orgCacheUsage =
        fromRightS (eitherDecodeStrict orgCacheUsagePayload)

    cacheListPayload :: ByteString
    cacheListPayload = $(embedFile "fixtures/actions/cache-list.json")

    repoCacheUsagePayload :: ByteString
    repoCacheUsagePayload = $(embedFile "fixtures/actions/repo-cache-usage.json")

    orgCacheUsagePayload :: ByteString
    orgCacheUsagePayload = $(embedFile "fixtures/actions/org-cache-usage.json")