aboutsummaryrefslogtreecommitdiff
path: root/server/src/Thermoprint/Server
diff options
context:
space:
mode:
Diffstat (limited to 'server/src/Thermoprint/Server')
-rw-r--r--server/src/Thermoprint/Server/Queue.hs19
1 files changed, 19 insertions, 0 deletions
diff --git a/server/src/Thermoprint/Server/Queue.hs b/server/src/Thermoprint/Server/Queue.hs
index cc87886..3c8fb9e 100644
--- a/server/src/Thermoprint/Server/Queue.hs
+++ b/server/src/Thermoprint/Server/Queue.hs
@@ -46,6 +46,11 @@ import Data.Foldable
46import Data.Monoid 46import Data.Monoid
47import Data.Ord 47import Data.Ord
48 48
49import Test.QuickCheck.Arbitrary (Arbitrary(..), CoArbitrary(..))
50import Test.QuickCheck.Gen (Gen, scale)
51import Test.QuickCheck.Instances
52import Test.QuickCheck.Modifiers
53
49-- | Zipper for 'Seq QueueEntry' with additional support for 'PrintingError' in the section after point 54-- | Zipper for 'Seq QueueEntry' with additional support for 'PrintingError' in the section after point
50data Queue = Queue 55data Queue = Queue
51 { pending :: Seq QueueEntry -- ^ Pending jobs, closest last 56 { pending :: Seq QueueEntry -- ^ Pending jobs, closest last
@@ -54,6 +59,14 @@ data Queue = Queue
54 } 59 }
55 deriving (Typeable, Generic, NFData, Show) 60 deriving (Typeable, Generic, NFData, Show)
56 61
62instance Arbitrary Queue where
63 arbitrary = Queue
64 <$> scale (`div` 2) arbitrary
65 <*> arbitrary
66 <*> scale (`div` 2) arbitrary
67
68instance CoArbitrary Queue
69
57class HasQueue a where 70class HasQueue a where
58 extractQueue :: a -> TVar Queue 71 extractQueue :: a -> TVar Queue
59 72
@@ -73,6 +86,12 @@ data QueueEntry = QueueEntry
73 } 86 }
74 deriving (Typeable, Generic, NFData, Eq, Ord, Show) 87 deriving (Typeable, Generic, NFData, Eq, Ord, Show)
75 88
89instance Arbitrary QueueEntry where
90 arbitrary = QueueEntry <$> (fromIntegral . getNonNegative <$> (arbitrary :: Gen (NonNegative Integer))) <*> arbitrary
91
92instance CoArbitrary QueueEntry where
93 coarbitrary QueueEntry{..} = coarbitrary created . coarbitrary (fromIntegral jobId :: Integer)
94
76data QueueItem = Pending Int QueueEntry | Current QueueEntry | History Int QueueEntry (Maybe PrintingError) 95data QueueItem = Pending Int QueueEntry | Current QueueEntry | History Int QueueEntry (Maybe PrintingError)
77 96
78instance Eq QueueItem where 97instance Eq QueueItem where