From 2ae720ab47213d93ffd22a40cd99b80bec1d022a Mon Sep 17 00:00:00 2001 From: Sibi Prabakaran Date: Sat, 13 Jun 2020 14:52:36 +0530 Subject: Initial support for benchmarks of the plugins --- bench/main.hs | 44 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 bench/main.hs (limited to 'bench') diff --git a/bench/main.hs b/bench/main.hs new file mode 100644 index 0000000..205acc8 --- /dev/null +++ b/bench/main.hs @@ -0,0 +1,44 @@ +{-#LANGUAGE RecordWildCards#-} + +import Gauge +import Xmobar +import Xmobar.Plugins.Monitors.Common.Types +import Xmobar.Plugins.Monitors.Common.Run +import Xmobar.Plugins.Monitors.Cpu +import Control.Monad.Reader +import Data.IORef (newIORef) + +main :: IO () +main = do + cpuParams <- mkCpuArgs + defaultMain $ normalBench cpuParams + where + normalBench args = [ bgroup "Cpu Benchmarks" $ normalCpuBench args] + +runMonitor :: MConfig -> Monitor a -> IO a +runMonitor config r = runReaderT r config + +data CpuArguments = CpuArguments { + cpuRef :: CpuDataRef, + cpuMConfig :: MConfig, + cpuArgs :: [String] + } + +mkCpuArgs :: IO CpuArguments +mkCpuArgs = do + cpuRef <- newIORef [] + _ <- parseCpu cpuRef + cpuMConfig <- cpuConfig + let cpuArgs = ["-L","3","-H","50","--normal","green","--high","red"] + pure $ CpuArguments {..} + +-- | The action which will be benchmarked +cpuAction :: CpuArguments -> IO String +cpuAction CpuArguments{..} = runMonitor cpuMConfig (doArgs cpuArgs (runCpu cpuRef) (\_ -> return True)) + + +cpuBenchmark :: CpuArguments -> Benchmarkable +cpuBenchmark cpuParams = nfIO $ cpuAction cpuParams + +normalCpuBench :: CpuArguments -> [Benchmark] +normalCpuBench args = [bench "CPU normal args" (cpuBenchmark args)] -- cgit v1.2.3