Test fix for #7853
authorMax Bolingbroke <batterseapower@hotmail.com>
Mon, 22 Apr 2013 20:23:49 +0000 (21:23 +0100)
committerMax Bolingbroke <batterseapower@hotmail.com>
Tue, 23 Apr 2013 20:12:34 +0000 (21:12 +0100)
tests/IO/T7853.hs [new file with mode: 0644]
tests/IO/T7853.stdout [new file with mode: 0644]
tests/IO/all.T

diff --git a/tests/IO/T7853.hs b/tests/IO/T7853.hs
new file mode 100644 (file)
index 0000000..382942e
--- /dev/null
@@ -0,0 +1,28 @@
+import qualified Data.ByteString as BS\r
+import System.IO\r
+import GHC.Foreign\r
+import Control.Exception\r
+import Data.Word\r
+\r
+decode :: TextEncoding -> BS.ByteString -> IO (Either SomeException String)\r
+decode enc bs = try $ BS.useAsCStringLen bs $ peekCStringLen enc\r
+\r
+main :: IO ()\r
+main = mapM_ go [ ["01111111"] -- (just fits into 1 byte)\r
+                , ["11000010", "10000000"] -- (just large enough for 2 bytes)\r
+                , ["11000001", "10111111"] -- (overlong: only 7 bits, so should fit into 1 byte)\r
+                , ["11011111", "10111111"] -- (just fits into 2 bytes)\r
+                , ["11100000", "10100000", "10000000"] -- (just large enough for 3 bytes)\r
+                , ["11100000", "10011111", "10111111"] -- (overlong: only 11 bits, so should fit into 2 bytes)\r
+                , ["11101111", "10111111", "10111111"] -- (just fits into 3 bytes)\r
+                , ["11110000", "10010000", "10000000", "10000000"] -- (just large enough for 4 bytes)\r
+                , ["11110000", "10001111", "10111111", "10111111"] -- (overlong: only 16 bits, so should fit into 3 bytes)\r
+                , ["11110100", "10001111", "10111111", "10111111"] -- (largest allowed codepoint)\r
+                , ["11110111", "10111111", "10111111", "10111111"] -- (just fits into 4 bytes but disallowed by RFC3629)\r
+                ]\r
+  where go xs = decode utf8 (BS.pack (map toByte xs)) >>= either (\_ -> putStrLn "Error") print\r
+\r
+toByte :: String -> Word8\r
+toByte [] = 0\r
+toByte ('1':xs) = (2 ^ length xs) + toByte xs\r
+toByte ('0':xs) = toByte xs\r
diff --git a/tests/IO/T7853.stdout b/tests/IO/T7853.stdout
new file mode 100644 (file)
index 0000000..09b25da
--- /dev/null
@@ -0,0 +1,11 @@
+"\DEL"
+"\128"
+Error
+"\2047"
+"\2048"
+Error
+"\65535"
+"\65536"
+Error
+"\1114111"
+Error
index 8272ef2..7d94e13 100644 (file)
@@ -162,3 +162,4 @@ test('encodingerror001', normal, compile_and_run, [''])
 
 test('T4808', [exit_code(1), extra_clean(['T4808.test'])], compile_and_run, [''])
 test('T4895', normal, compile_and_run, [''])
+test('T7853', normal, compile_and_run, [''])