diff --git a/ghc/tests/array/should_run/arr014.hs b/ghc/tests/array/should_run/arr014.hs
new file mode 100644
index 0000000000000000000000000000000000000000..86996a10d1646976778e2c3e76ed6f2f8cac7558
--- /dev/null
+++ b/ghc/tests/array/should_run/arr014.hs
@@ -0,0 +1,28 @@
+{-# OPTIONS -fglasgow-exts #-}
+
+--!!! multi-dimensional arrays
+
+module Main ( main ) where
+import GlaExts
+import Array
+
+type TwoD s = MutableArray s Int (MutableArray s Int Int)
+
+setup :: ST s (TwoD s)
+setup = let isz = 10
+            imax = isz - 1	  
+            osz = 2
+            omax = osz - 1 in
+	do
+            -- gives : undefined reference to `IOBase_error_closure'
+--	    x <- newArray (0, omax) (error "uninitialised")
+	    dmy <- newArray (0, imax) 0      
+	    x <- newArray (0, omax) dmy
+	    as <- (accumulate . replicate osz) (newArray (0, imax) 6)
+	    mapM_ (\(i,v) -> writeArray x i v) (zip [0..omax] as)
+	    return x	  
+
+main :: IO ()
+main = do
+         a <- stToIO setup
+	 return ()	 
diff --git a/ghc/tests/array/should_run/arr014.stdout b/ghc/tests/array/should_run/arr014.stdout
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391