File: Comonad.hs

package info (click to toggle)
haskell-hedgehog-classes 0.2.5.4-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 508 kB
  • sloc: haskell: 6,010; makefile: 8
file content (54 lines) | stat: -rw-r--r-- 1,478 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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
{-# language
        DerivingStrategies
      , GeneralizedNewtypeDeriving
  #-}

{-# options_ghc -fno-warn-orphans #-}

module Spec.Comonad
  ( testComonad
  ) where

import Data.List.NonEmpty
import Control.Applicative (liftA2)
import Control.Comonad
import Control.Comonad.Store hiding (store)
import Data.Functor.Identity (Identity(..))
import Hedgehog
import Hedgehog.Classes
import Prelude hiding (either)
import qualified Hedgehog.Gen as Gen
import qualified Hedgehog.Range as Range

testComonad :: [(String, [Laws])]
testComonad =
  [ ("Identity", [comonadLaws identity])
  , ("NonEmpty", [comonadLaws nonempty])
  , ("(,) e", [comonadLaws tup])
  , ("StoreT Integer Identity", [comonadLaws store])
  ]

store :: MonadGen m => m a -> m (StoreT Integer Identity a)
store gen = do
  a <- gen
  pure $ StoreT (Identity (const a)) 20

instance (Comonad w, Show s, Show a) => Show (StoreT s w a) where
  show (StoreT wf s) = show $ "StoreT { s = " ++ show s ++ ", extract stuff = " ++ show (extract wf s) ++ "}"

instance (Comonad w, Eq a) => Eq (StoreT s w a) where
  StoreT wf s == StoreT wf' s' = extract wf s == extract wf' s'

identity :: MonadGen m => m a -> m (Identity a)
identity = fmap Identity

nonempty :: MonadGen m => m a -> m (NonEmpty a)
nonempty gen = liftA2 (:|) gen (list gen)

tup :: MonadGen m => m a -> m (Integer, a)
tup gen = (,)
  <$> Gen.integral (Range.linear 20 50)
  <*> gen

list :: MonadGen m => m a -> m [a]
list = Gen.list $ Range.linear 0 6