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 55 56 57 58
|
module ItemRevUnitTests (itemRevUnitTests) where
import Prelude ()
import Game.LambdaHack.Core.Prelude
import qualified Control.Monad.Trans.State.Strict as St
import qualified Data.EnumMap.Strict as EM
import qualified Data.EnumSet as ES
import qualified Data.Vector.Unboxed as U
import qualified System.Random.SplitMix32 as SM
import Test.Tasty
import Test.Tasty.HUnit
import Game.LambdaHack.Common.Kind (emptyMultiGroupItem)
import Game.LambdaHack.Content.ItemKind
import Game.LambdaHack.Core.Random
import Game.LambdaHack.Definition.Color
import Game.LambdaHack.Definition.DefsInternal
import Game.LambdaHack.Definition.Flavour
import Game.LambdaHack.Server.ItemRev
itemRevUnitTests :: TestTree
itemRevUnitTests = testGroup "itemRevUnitTests" $
let testItemKind2Flavours = emptyMultiGroupItem
{ iflavour = zipStory [Black,Green] }
emptyIdToFlavourSymbolToFlavourSetPair = ( EM.empty, EM.empty )
singletonIdToFlavourSymbolToFlavourSetPair =
( EM.singleton (toContentId 0) dummyFlavour
, EM.singleton 'x' (ES.singleton dummyFlavour) )
flavourBlack = head $ zipStory [Black]
flavourGreen = head $ zipStory [Green]
in
[ testCase "empty & default initializers -> first is single dummy result" $
let rndMapPair0 = return emptyIdToFlavourSymbolToFlavourSetPair
mapPair1 = St.evalState (rollFlavourMap U.empty rndMapPair0 (toContentId 0) emptyMultiGroupItem) $ SM.mkSMGen 1
in fst mapPair1 @?= EM.singleton (toContentId 0) dummyFlavour
, testCase "empty & default initializers -> second is empty" $
let rndMapPair0 = return emptyIdToFlavourSymbolToFlavourSetPair
(mapPair1, _) = St.runState (rollFlavourMap U.empty rndMapPair0 (toContentId 0) emptyMultiGroupItem) $ SM.mkSMGen 1
in snd mapPair1 @?= EM.empty
, testCase "singleton initializers -> first is single dummy result" $
let rndMapPair0 = return singletonIdToFlavourSymbolToFlavourSetPair
(mapPair1, _) = St.runState (rollFlavourMap U.empty rndMapPair0 (toContentId 0) emptyMultiGroupItem) $ SM.mkSMGen 1
in fst mapPair1 @?= EM.singleton (toContentId 0) dummyFlavour
, testCase "singleton initializers -> second is single dummy result" $
let rndMapPair0 = return singletonIdToFlavourSymbolToFlavourSetPair
(mapPair1, _) = St.runState (rollFlavourMap U.empty rndMapPair0 (toContentId 0) emptyMultiGroupItem) $ SM.mkSMGen 1
in snd mapPair1 @?= EM.singleton 'x' (ES.singleton dummyFlavour)
, testCase "rollFlavourMap on two flavours -> first flavour can be rolled" $ -- relies on us not messing with RNG
let rndMapPair0 = return singletonIdToFlavourSymbolToFlavourSetPair
(mapPair1, _) = St.runState (rollFlavourMap (U.singleton invalidInformationCode) rndMapPair0 (toContentId 0) testItemKind2Flavours) $ SM.mkSMGen 1
in fst mapPair1 @?= EM.singleton (toContentId 0) flavourBlack
, testCase "rollFlavourMap on two flavours -> second flavour can be rolled" $ -- relies on us not messing with RNG
let rndMapPair0 = return singletonIdToFlavourSymbolToFlavourSetPair
(mapPair1, _) = St.runState (rollFlavourMap (U.singleton invalidInformationCode) rndMapPair0 (toContentId 0) testItemKind2Flavours) $ SM.mkSMGen 2
in fst mapPair1 @?= EM.singleton (toContentId 0) flavourGreen
]
|