{-# LANGUAGE TemplateHaskell #-} -- Copyright (C) 2010-2012 John Millikin -- -- This program is free software: you can redistribute it and/or modify -- it under the terms of the GNU General Public License as published by -- the Free Software Foundation, either version 3 of the License, or -- any later version. -- -- This program is distributed in the hope that it will be useful, -- but WITHOUT ANY WARRANTY; without even the implied warranty of -- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -- GNU General Public License for more details. -- -- You should have received a copy of the GNU General Public License -- along with this program. If not, see . module DBusTests.ObjectPath (test_ObjectPath) where import Test.Chell import Test.Chell.QuickCheck import Test.QuickCheck hiding (property) import Data.List (intercalate) import DBus test_ObjectPath :: Suite test_ObjectPath = suite "ObjectPath" test_Parse test_ParseInvalid test_Parse :: Test test_Parse = property "parse" prop where prop = forAll gen_ObjectPath check check x = case parseObjectPath x of Nothing -> False Just parsed -> formatObjectPath parsed == x test_ParseInvalid :: Test test_ParseInvalid = assertions "parse-invalid" $ do -- empty $expect (nothing (parseObjectPath "")) -- bad char $expect (nothing (parseObjectPath "/f!oo")) -- ends with a slash $expect (nothing (parseObjectPath "/foo/")) -- empty element $expect (nothing (parseObjectPath "/foo//bar")) -- trailing chars $expect (nothing (parseObjectPath "/foo!")) gen_ObjectPath :: Gen String gen_ObjectPath = gen where chars = ['a'..'z'] ++ ['A'..'Z'] ++ ['0'..'9'] ++ "_" gen = do xs <- listOf (listOf1 (elements chars)) return ("/" ++ intercalate "/" xs) instance Arbitrary ObjectPath where arbitrary = fmap objectPath_ gen_ObjectPath