summaryrefslogtreecommitdiffhomepage
path: root/tests
diff options
context:
space:
mode:
authorŁukasz Gołębiewski <lukasz.golebiewski@gmail.com>2020-01-26 11:36:49 +0000
committerGitHub <noreply@github.com>2020-01-26 11:36:49 +0000
commitb501e5c92dac8b89ff0c1f962a4be4ecbc261e97 (patch)
treeab882893d57edad78ce6de5ae68f274c83404ae9 /tests
parent5eb4902883d9d3937641d6a2c6249993242bf098 (diff)
downloadstylish-haskell-b501e5c92dac8b89ff0c1f962a4be4ecbc261e97.tar.gz
Expose "format" function in Sylish.hs (#259)
* Expose "format" function in Sylish.hs It's going to be needed for the haskell-ide integration * Update tests/Language/Haskell/StylishSpec.hs Co-Authored-By: Jasper Van der Jeugt <jaspervdj@gmail.com> * Remove empty line Co-authored-by: Jasper Van der Jeugt <jaspervdj@gmail.com>
Diffstat (limited to 'tests')
-rw-r--r--tests/Language/Haskell/StylishSpec.hs51
-rw-r--r--tests/TestSuite.hs4
2 files changed, 54 insertions, 1 deletions
diff --git a/tests/Language/Haskell/StylishSpec.hs b/tests/Language/Haskell/StylishSpec.hs
new file mode 100644
index 0000000..77a23b1
--- /dev/null
+++ b/tests/Language/Haskell/StylishSpec.hs
@@ -0,0 +1,51 @@
+module Language.Haskell.StylishSpec where
+
+--------------------------------------------------------------------------------
+import Test.Framework (Test, testGroup)
+import Test.Framework.Providers.HUnit (testCase)
+import Test.HUnit (Assertion, (@?=))
+
+--------------------------------------------------------------------------------
+import Language.Haskell.Stylish
+
+--------------------------------------------------------------------------------
+import System.IO.Unsafe
+--------------------------------------------------------------------------------
+tests :: Test
+tests = testGroup "Language.Haskell.Stylish.Step.Tabs.Tests"
+ [ testCase "case 01" case01
+ , testCase "case 02" case02
+ , testCase "case 03" case03
+ ]
+
+--------------------------------------------------------------------------------
+case01 :: Assertion
+case01 = (@?=) result (unsafePerformIO $ format Nothing Nothing input)
+ where
+ input = "module Herp where\n data Foo = Bar | Baz"
+ result = Right [ "module Herp where"
+ , "data Foo = Bar"
+ , " | Baz"
+ ]
+
+case02 :: Assertion
+case02 = (@?=) result (unsafePerformIO $ format (Just configLocation) Nothing input)
+ where
+ configLocation = ConfigPath "testdata/test-config.yaml"
+ input = "module Herp where\n data Foo = Bar | Baz"
+ result = Right [ "module Herp where"
+ , "data Foo = Bar"
+ , " | Baz"
+ ]
+
+case03 :: Assertion
+case03 = do
+ actual <- format Nothing (Just fileLocation) input
+ actual @?= result
+ where
+ fileLocation = "directory/File.hs"
+ input = "module Herp"
+ result = Left $
+ "Language.Haskell.Stylish.Parse.parseModule: could not parse " <>
+ fileLocation <>
+ ": ParseFailed (SrcLoc \"<unknown>.hs\" 2 1) \"Parse error: EOF\""
diff --git a/tests/TestSuite.hs b/tests/TestSuite.hs
index a6f51ea..1138323 100644
--- a/tests/TestSuite.hs
+++ b/tests/TestSuite.hs
@@ -19,12 +19,14 @@ import qualified Language.Haskell.Stylish.Step.Squash.Tests
import qualified Language.Haskell.Stylish.Step.Tabs.Tests
import qualified Language.Haskell.Stylish.Step.TrailingWhitespace.Tests
import qualified Language.Haskell.Stylish.Step.UnicodeSyntax.Tests
+import qualified Language.Haskell.StylishSpec
--------------------------------------------------------------------------------
main :: IO ()
main = defaultMain
- [ Language.Haskell.Stylish.Parse.Tests.tests
+ [ Language.Haskell.StylishSpec.tests
+ , Language.Haskell.Stylish.Parse.Tests.tests
, Language.Haskell.Stylish.Config.Tests.tests
, Language.Haskell.Stylish.Step.Data.Tests.tests
, Language.Haskell.Stylish.Step.Imports.Tests.tests