File: WeightedPSQ.hs

package info (click to toggle)
haskell-cabal-install 3.10.3.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, trixie
  • size: 3,400 kB
  • sloc: haskell: 52,202; sh: 80; makefile: 9
file content (54 lines) | stat: -rw-r--r-- 2,011 bytes parent folder | download | duplicates (6)
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 ParallelListComp #-}
module UnitTests.Distribution.Solver.Modular.WeightedPSQ (
  tests
  ) where

import qualified Distribution.Solver.Modular.WeightedPSQ as W

import Data.List (sort)

import Test.Tasty (TestTree)
import Test.Tasty.HUnit (testCase, (@?=))
import Test.Tasty.QuickCheck (Blind(..), testProperty)

tests :: [TestTree]
tests = [
    testProperty "'toList . fromList' preserves elements" $ \xs ->
        sort (xs :: [(Int, Char, Bool)]) == sort (W.toList (W.fromList xs))

  , testProperty "'toList . fromList' sorts stably" $ \xs ->
        let indexAsValue :: [(Int, (), Int)]
            indexAsValue = [(x, (), i) | x <- xs | i <- [0..]]
        in isSorted $ W.toList $ W.fromList indexAsValue

  , testProperty "'mapWeightsWithKey' sorts by weight" $ \xs (Blind f) ->
        isSorted $ W.weights $
        W.mapWeightsWithKey (f :: Int -> Int -> Int) $
        W.fromList (xs :: [(Int, Int, Int)])

  , testCase "applying 'mapWeightsWithKey' twice sorts twice" $
        let indexAsKey :: [((), Int, ())]
            indexAsKey = [((), i, ()) | i <- [0..10]]
            actual = W.toList $
                     W.mapWeightsWithKey (\_ _ -> ()) $
                     W.mapWeightsWithKey (\i _ -> -i) $ -- should not be ignored
                     W.fromList indexAsKey
        in reverse indexAsKey @?= actual

  , testProperty "'union' sorts by weight" $ \xs ys ->
        isSorted $ W.weights $
        W.union (W.fromList xs) (W.fromList (ys :: [(Int, Int, Int)]))

  , testProperty "'union' preserves elements" $ \xs ys ->
        let union = W.union (W.fromList xs)
                            (W.fromList (ys :: [(Int, Int, Int)]))
        in sort (xs ++ ys) == sort (W.toList union)

  , testCase "'lookup' returns first occurrence" $
        let xs = W.fromList [((), False, 'A'), ((), True, 'C'), ((), True, 'B')]
        in Just 'C' @?= W.lookup True xs
  ]

isSorted :: Ord a => [a] -> Bool
isSorted (x1 : xs@(x2 : _)) = x1 <= x2 && isSorted xs
isSorted _ = True