{-# LANGUAGE OverloadedStrings #-} {-| Module : Main Copyright : © 2019 Albert Krewinkel License : MIT Maintainer : Albert Krewinkel Stability : alpha Portability : Requires language extensions ForeignFunctionInterface, OverloadedStrings. Tests for the `system` Lua module. -} import Control.Monad (void, when) import Foreign.Lua (Lua) import Foreign.Lua.Module.System (preloadModule, pushModule) import Test.Tasty (TestTree, defaultMain, testGroup) import Test.Tasty.HUnit (assertEqual, testCase) import qualified Foreign.Lua as Lua main :: IO () main = defaultMain $ testGroup "hslua-module-system" [tests] -- | HSpec tests for the Lua 'system' module tests :: TestTree tests = testGroup "HsLua System module" [ testCase "system module can be pushed to the stack" $ Lua.run (void pushModule) , testCase "system module can be added to the preloader" . Lua.run $ do Lua.openlibs preloadModule "system" assertEqual' "function not added to preloader" Lua.TypeFunction =<< do Lua.getglobal' "package.preload.system" Lua.ltype (-1) , testCase "system module can be loaded as hssystem" . Lua.run $ do Lua.openlibs preloadModule "hssystem" assertEqual' "loading the module fails " Lua.OK =<< Lua.dostring "require 'hssystem'" , testCase "Lua tests pass" . Lua.run $ do Lua.openlibs preloadModule "system" assertEqual' "error while running lua tests" Lua.OK =<< do st <- Lua.loadfile "test/system-module-tests.lua" when (st == Lua.OK) $ Lua.call 0 0 return st ] assertEqual' :: (Show a, Eq a) => String -> a -> a -> Lua () assertEqual' msg expected = Lua.liftIO . assertEqual msg expected