-- Copyright (C) 2010-2012 John Millikin -- -- 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 -- -- http://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. module DBusTests.BusName (test_BusName) where import Data.List (intercalate) import Data.Maybe (isJust) import Test.QuickCheck import Test.Tasty import Test.Tasty.HUnit import Test.Tasty.QuickCheck import DBus import DBusTests.Util test_BusName :: TestTree test_BusName = testGroup "BusName" [ test_Parse , test_ParseInvalid , test_IsVariant ] test_Parse :: TestTree test_Parse = testProperty "parse" prop where prop = forAll gen_BusName check check x = case parseBusName x of Nothing -> False Just parsed -> formatBusName parsed == x test_ParseInvalid :: TestTree test_ParseInvalid = testCase "parse-invalid" $ do -- empty Nothing @=? parseBusName "" -- well-known starting with a digit Nothing @=? parseBusName "foo.0bar" -- well-known with one element Nothing @=? parseBusName "foo" -- unique with one element Nothing @=? parseBusName ":foo" -- trailing characters Nothing @=? parseBusName "foo.bar!" -- at most 255 characters assertBool "valid parse failed" $ isJust (parseBusName (":0." ++ replicate 251 'y')) assertBool "valid parse failed" $ isJust (parseBusName (":0." ++ replicate 252 'y')) Nothing @=? parseBusName (":0." ++ replicate 253 'y') test_IsVariant :: TestTree test_IsVariant = testCase "IsVariant" $ assertVariant TypeString (busName_ "foo.bar") gen_BusName :: Gen String gen_BusName = oneof [unique, wellKnown] where alpha = ['a'..'z'] ++ ['A'..'Z'] ++ "_-" alphanum = alpha ++ ['0'..'9'] unique = trim $ do x <- chunks alphanum return (":" ++ x) wellKnown = trim (chunks alpha) trim gen = do x <- gen if length x > 255 then return (dropWhileEnd (== '.') (take 255 x)) else return x chunks start = do x <- chunk start xs <- listOf1 (chunk start) return (intercalate "." (x:xs)) chunk start = do x <- elements start xs <- listOf (elements alphanum) return (x:xs) instance Arbitrary BusName where arbitrary = fmap busName_ gen_BusName