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 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
-- Copyright (C) 2010-2012 John Millikin <john@john-millikin.com>
--
-- 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
|