duckling/tests/Duckling/Engine/Tests.hs

54 lines
1.3 KiB
Haskell
Raw Normal View History

-- Copyright (c) 2016-present, Facebook, Inc.
-- All rights reserved.
--
-- This source code is licensed under the BSD-style license found in the
-- LICENSE file in the root directory of this source tree. An additional grant
-- of patent rights can be found in the PATENTS file in the same directory.
{-# LANGUAGE OverloadedStrings #-}
module Duckling.Engine.Tests
( tests
) where
import Data.String
import Prelude
import Test.Tasty
import Test.Tasty.HUnit
import Duckling.Engine
import Duckling.Types
import Duckling.Dimensions.Types
import Duckling.Regex.Types
tests :: TestTree
tests = testGroup "Engine Tests"
[ emptyRegexTest
, unicodeAndRegexTest
]
emptyRegexTest :: TestTree
emptyRegexTest = testCase "Empty Regex Test" $
case regex "()" of
Regex regex -> assertEqual "empty result" [] $
runDuckling $ lookupRegex regex 0 "hey"
_ -> assertFailure "expected a regex"
unicodeAndRegexTest :: TestTree
unicodeAndRegexTest = testCase "Unicode and Regex Test" $
case regex "\\$([0-9]*)" of
Regex regex -> do --
assertEqual "" expected $
runDuckling $ lookupRegex regex 0 "\128526 $35"
_ -> assertFailure "expected a regex"
where
expected =
[ Node
{ nodeRange = Range 2 5
, token = Token RegexMatch (GroupMatch ["35"])
, children = []
, rule = Nothing
}
]