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 55 56 57 58 59 60 61
|
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE TypeApplications #-}
{-|
Module : Main
Copyright : © 2021-2024 Albert Krewinkel
License : MIT
Maintainer : Albert Krewinkel <tarleb@hslua.org>
Stability : stable
Portability : Requires language extensions ForeignFunctionInterface,
OverloadedStrings.
Tests for the `zip` Lua module.
-}
module Main (main) where
import Control.Monad (void)
import HsLua.Core (Lua, top)
import HsLua.Packaging ( preloadModule, preloadModuleWithName, pushModule
, registerModule)
import HsLua.Module.Zip (documentedModule)
import Test.Tasty (TestTree, defaultMain, testGroup)
import Test.Tasty.HUnit (assertEqual, testCase)
import Test.Tasty.Lua (translateResultsFromFile)
import qualified HsLua.Core as Lua
import qualified HsLua.Module.System as System
main :: IO ()
main = do
luaTestResults <- Lua.run @Lua.Exception $ do
Lua.openlibs
registerModule documentedModule
registerModule System.documentedModule
Lua.pop 1
translateResultsFromFile "test/test-zip.lua"
defaultMain $ testGroup "hslua-module-zip" [tests, luaTestResults]
-- | HSpec tests for the Lua 'system' module
tests :: TestTree
tests = testGroup "HsLua zip module"
[ testCase "zip module can be pushed to the stack" $
Lua.run (void (pushModule documentedModule) :: Lua ())
, testCase "zip module can be added to the preloader" . Lua.run $ do
Lua.openlibs
preloadModule documentedModule
assertEqual' "function not added to preloader" Lua.TypeFunction =<< do
void $ Lua.getglobal "package"
*> Lua.getfield top "preload"
*> Lua.getfield top "zip"
Lua.ltype (-1)
, testCase "zip module can be loaded as hszip" . Lua.run $ do
Lua.openlibs
preloadModuleWithName documentedModule "hszip"
assertEqual' "loading the module fails " Lua.OK =<<
Lua.dostring "require 'hszip'"
]
assertEqual' :: (Show a, Eq a) => String -> a -> a -> Lua ()
assertEqual' msg expected = Lua.liftIO . assertEqual msg expected
|