File: Main.hs

package info (click to toggle)
haskell-ogma-language-c 1.10.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 96 kB
  • sloc: haskell: 42; ansic: 16; makefile: 6
file content (55 lines) | stat: -rw-r--r-- 2,042 bytes parent folder | download
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
-- Copyright 2020 United States Government as represented by the Administrator
-- of the National Aeronautics and Space Administration. All Rights Reserved.
--
-- Disclaimers
--
-- Licensed under the Apache License, Version 2.0 (the "License"); you may
-- not use this file except in compliance with the License. You may obtain a
-- copy of the License at
--
--      https://www.apache.org/licenses/LICENSE-2.0
--
-- Unless required by applicable law or agreed to in writing, software
-- distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
-- WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
-- License for the specific language governing permissions and limitations
-- under the License.
--
-- | Test C language library.
module Main where

-- External imports
import Data.Either                          ( isLeft, isRight )
import Test.Framework                       ( Test, defaultMainWithOpts )
import Test.Framework.Providers.QuickCheck2 ( testProperty )
import Test.QuickCheck                      ( Property )
import Test.QuickCheck.Monadic              ( assert, monadicIO, run )

-- Internal imports
import qualified Language.C.ParC as C ( myLexer, pTranslationUnit )

-- | Run all unit tests for the C parser.
main :: IO ()
main =
  defaultMainWithOpts tests mempty

-- | All unit tests for the C parser.
tests :: [Test.Framework.Test]
tests =
  [ testProperty "Parse C (correct header case)"   propParseCOk
  , testProperty "Parse C (incorrect header case)" propParseCFail
  ]

-- | Test the C parser on a well-formed header file.
propParseCOk :: Property
propParseCOk = monadicIO $ do
  content <- run $ readFile "tests/reduced_geofence_msgs.h"
  let program = C.pTranslationUnit $ C.myLexer content
  assert (isRight program)

-- | Test the C parser on an incorrect header file.
propParseCFail :: Property
propParseCFail = monadicIO $ do
  content <- run $ readFile "tests/reduced_geofence_msgs_bad.h"
  let program = C.pTranslationUnit $ C.myLexer content
  assert (isLeft program)