Add regression test for #11966
authorRyan Scott <ryan.gl.scott@gmail.com>
Fri, 12 May 2017 12:57:26 +0000 (08:57 -0400)
committerRyan Scott <ryan.gl.scott@gmail.com>
Fri, 12 May 2017 12:57:28 +0000 (08:57 -0400)
Commit a7ee2d4c4229b27af324ebac93081f692835365d fixed #11966. Here's a
regression test for it.

testsuite/tests/dependent/should_compile/T11966.hs [new file with mode: 0644]
testsuite/tests/dependent/should_compile/all.T

diff --git a/testsuite/tests/dependent/should_compile/T11966.hs b/testsuite/tests/dependent/should_compile/T11966.hs
new file mode 100644 (file)
index 0000000..0262a0a
--- /dev/null
@@ -0,0 +1,34 @@
+{-# LANGUAGE TypeFamilies #-}
+{-# LANGUAGE DataKinds #-}
+{-# LANGUAGE KindSignatures #-}
+{-# LANGUAGE PolyKinds #-}
+{-# LANGUAGE RankNTypes #-}
+{-# LANGUAGE TypeInType #-}
+{-# LANGUAGE TypeOperators #-}
+
+module T11966 where
+
+import Data.Kind (Type)
+import GHC.TypeLits (Symbol)
+
+-- Simplification
+type family Col (f :: k -> j) (x :: k) :: Type
+
+-- Base types
+data PGBaseType = PGInteger | PGText
+
+-- Transformations
+data Column t = Column Symbol t
+newtype Nullable t = Nullable t
+newtype HasDefault t = HasDefault t
+
+-- Interpretations
+data Expr k
+
+data Record (f :: forall k. k -> Type) =
+  Record {rX :: Col f ('Column "x" 'PGInteger)
+         ,rY :: Col f ('Column "y" ('Nullable 'PGInteger))
+         ,rZ :: Col f ('HasDefault 'PGText)}
+
+x :: Record Expr
+x = undefined
index a921743..8a9b221 100644 (file)
@@ -21,5 +21,6 @@ test('T11711', normal, compile, [''])
 test('RaeJobTalk', normal, compile, [''])
 test('T11635', normal, compile, [''])
 test('T11719', normal, compile, [''])
+test('T11966', normal, compile, [''])
 test('T12442', normal, compile, [''])
 test('T13538', normal, compile, [''])