added gmsGoalsFor and gmsGoalsAgainst fields to GameStats
This commit is contained in:
parent
5332dc0d7f
commit
9f68d0da1d
|
@ -95,6 +95,8 @@ module Mtlstats.Types (
|
||||||
gmsWins,
|
gmsWins,
|
||||||
gmsLosses,
|
gmsLosses,
|
||||||
gmsOvertime,
|
gmsOvertime,
|
||||||
|
gmsGoalsFor,
|
||||||
|
gmsGoalsAgainst,
|
||||||
-- * Constructors
|
-- * Constructors
|
||||||
newProgState,
|
newProgState,
|
||||||
newGameState,
|
newGameState,
|
||||||
|
@ -411,6 +413,10 @@ data GameStats = GameStats
|
||||||
-- ^ Games lost
|
-- ^ Games lost
|
||||||
, _gmsOvertime :: Int
|
, _gmsOvertime :: Int
|
||||||
-- ^ Games lost in overtime
|
-- ^ Games lost in overtime
|
||||||
|
, _gmsGoalsFor :: Int
|
||||||
|
-- ^ Goals for the team
|
||||||
|
, _gmsGoalsAgainst :: Int
|
||||||
|
-- ^ Goals against the team
|
||||||
} deriving (Eq, Show)
|
} deriving (Eq, Show)
|
||||||
|
|
||||||
instance FromJSON GameStats where
|
instance FromJSON GameStats where
|
||||||
|
@ -418,17 +424,23 @@ instance FromJSON GameStats where
|
||||||
<$> v .: "wins"
|
<$> v .: "wins"
|
||||||
<*> v .: "losses"
|
<*> v .: "losses"
|
||||||
<*> v .: "overtime"
|
<*> v .: "overtime"
|
||||||
|
<*> v .: "goals_for"
|
||||||
|
<*> v .: "goals_against"
|
||||||
|
|
||||||
instance ToJSON GameStats where
|
instance ToJSON GameStats where
|
||||||
toJSON (GameStats w l ot) = object
|
toJSON (GameStats w l ot gf ga) = object
|
||||||
[ "wins" .= w
|
[ "wins" .= w
|
||||||
, "losses" .= l
|
, "losses" .= l
|
||||||
, "overtime" .= ot
|
, "overtime" .= ot
|
||||||
|
, "goals_for" .= gf
|
||||||
|
, "goals_against" .= ga
|
||||||
]
|
]
|
||||||
toEncoding (GameStats w l ot) = pairs $
|
toEncoding (GameStats w l ot gf ga) = pairs $
|
||||||
"wins" .= w <>
|
"wins" .= w <>
|
||||||
"losses" .= l <>
|
"losses" .= l <>
|
||||||
"overtime" .= ot
|
"overtime" .= ot <>
|
||||||
|
"goals_for" .= gf <>
|
||||||
|
"goals_against" .= ga
|
||||||
|
|
||||||
-- | Defines a user prompt
|
-- | Defines a user prompt
|
||||||
data Prompt = Prompt
|
data Prompt = Prompt
|
||||||
|
@ -566,6 +578,8 @@ newGameStats = GameStats
|
||||||
{ _gmsWins = 0
|
{ _gmsWins = 0
|
||||||
, _gmsLosses = 0
|
, _gmsLosses = 0
|
||||||
, _gmsOvertime = 0
|
, _gmsOvertime = 0
|
||||||
|
, _gmsGoalsFor = 0
|
||||||
|
, _gmsGoalsAgainst = 0
|
||||||
}
|
}
|
||||||
|
|
||||||
-- | Determines the team's score
|
-- | Determines the team's score
|
||||||
|
@ -635,6 +649,8 @@ addGameStats s1 s2 = GameStats
|
||||||
{ _gmsWins = s1^.gmsWins + s2^.gmsWins
|
{ _gmsWins = s1^.gmsWins + s2^.gmsWins
|
||||||
, _gmsLosses = s1^.gmsLosses + s2^.gmsLosses
|
, _gmsLosses = s1^.gmsLosses + s2^.gmsLosses
|
||||||
, _gmsOvertime = s1^.gmsOvertime + s2^.gmsOvertime
|
, _gmsOvertime = s1^.gmsOvertime + s2^.gmsOvertime
|
||||||
|
, _gmsGoalsFor = s1^.gmsGoalsFor + s2^.gmsGoalsFor
|
||||||
|
, _gmsGoalsAgainst = s1^.gmsGoalsAgainst + s2^.gmsGoalsAgainst
|
||||||
}
|
}
|
||||||
|
|
||||||
-- | Calculates a player's points
|
-- | Calculates a player's points
|
||||||
|
|
|
@ -258,6 +258,8 @@ gameStats n = GameStats
|
||||||
{ _gmsWins = n
|
{ _gmsWins = n
|
||||||
, _gmsLosses = n + 1
|
, _gmsLosses = n + 1
|
||||||
, _gmsOvertime = n + 2
|
, _gmsOvertime = n + 2
|
||||||
|
, _gmsGoalsFor = n + 3
|
||||||
|
, _gmsGoalsAgainst = n + 4
|
||||||
}
|
}
|
||||||
|
|
||||||
gameStatsJSON :: Int -> Value
|
gameStatsJSON :: Int -> Value
|
||||||
|
@ -265,6 +267,8 @@ gameStatsJSON n = Object $ HM.fromList
|
||||||
[ ( "wins", toJSON n )
|
[ ( "wins", toJSON n )
|
||||||
, ( "losses", toJSON $ n + 1 )
|
, ( "losses", toJSON $ n + 1 )
|
||||||
, ( "overtime", toJSON $ n + 2 )
|
, ( "overtime", toJSON $ n + 2 )
|
||||||
|
, ( "goals_for", toJSON $ n + 3 )
|
||||||
|
, ( "goals_against", toJSON $ n + 4 )
|
||||||
]
|
]
|
||||||
|
|
||||||
db :: Database
|
db :: Database
|
||||||
|
@ -456,11 +460,11 @@ gmsGamesSpec = describe "gmsGames" $ mapM_
|
||||||
gmsPointsSpec :: Spec
|
gmsPointsSpec :: Spec
|
||||||
gmsPointsSpec = describe "gmsPoints" $ mapM_
|
gmsPointsSpec = describe "gmsPoints" $ mapM_
|
||||||
(\(w, l, ot, expected) -> let
|
(\(w, l, ot, expected) -> let
|
||||||
gs = GameStats
|
gs
|
||||||
{ _gmsWins = w
|
= newGameStats
|
||||||
, _gmsLosses = l
|
& gmsWins .~ w
|
||||||
, _gmsOvertime = ot
|
& gmsLosses .~ l
|
||||||
}
|
& gmsOvertime .~ ot
|
||||||
in context (show gs) $
|
in context (show gs) $
|
||||||
it ("should be " ++ show expected) $
|
it ("should be " ++ show expected) $
|
||||||
gmsPoints gs `shouldBe` expected)
|
gmsPoints gs `shouldBe` expected)
|
||||||
|
@ -479,20 +483,26 @@ addGameStatsSpec = describe "addGameStats" $
|
||||||
|
|
||||||
s1 = GameStats
|
s1 = GameStats
|
||||||
{ _gmsWins = 1
|
{ _gmsWins = 1
|
||||||
, _gmsLosses = 3
|
, _gmsLosses = 2
|
||||||
, _gmsOvertime = 2
|
, _gmsOvertime = 3
|
||||||
|
, _gmsGoalsFor = 4
|
||||||
|
, _gmsGoalsAgainst = 5
|
||||||
}
|
}
|
||||||
|
|
||||||
s2 = GameStats
|
s2 = GameStats
|
||||||
{ _gmsWins = 4
|
{ _gmsWins = 6
|
||||||
, _gmsLosses = 6
|
, _gmsLosses = 7
|
||||||
, _gmsOvertime = 5
|
, _gmsOvertime = 8
|
||||||
|
, _gmsGoalsFor = 9
|
||||||
|
, _gmsGoalsAgainst = 10
|
||||||
}
|
}
|
||||||
|
|
||||||
expected = GameStats
|
expected = GameStats
|
||||||
{ _gmsWins = 5
|
{ _gmsWins = 7
|
||||||
, _gmsLosses = 9
|
, _gmsLosses = 9
|
||||||
, _gmsOvertime = 7
|
, _gmsOvertime = 11
|
||||||
|
, _gmsGoalsFor = 13
|
||||||
|
, _gmsGoalsAgainst = 15
|
||||||
}
|
}
|
||||||
|
|
||||||
in addGameStats s1 s2 `shouldBe` expected
|
in addGameStats s1 s2 `shouldBe` expected
|
||||||
|
|
Loading…
Reference in New Issue
Block a user