diff --git a/testsuite/tests/typecheck/should_fail/T16394.hs b/testsuite/tests/typecheck/should_fail/T16394.hs new file mode 100644 index 0000000000000000000000000000000000000000..76ca7a7cf61dacdff752a67ad0726bc4f2f6a98b --- /dev/null +++ b/testsuite/tests/typecheck/should_fail/T16394.hs @@ -0,0 +1,12 @@ +{-# LANGUAGE PolyKinds, TypeFamilies, DataKinds #-} + +class C a where + type T (n :: a) + +instance C a => C b => C (a, b) where + type T '(n, m) = (T n, T m) + +-- but this worked fine: +-- +-- instance (C a, C b) => C (a, b) where +-- type T '(n, m) = (T n, T m) diff --git a/testsuite/tests/typecheck/should_fail/T16394.stderr b/testsuite/tests/typecheck/should_fail/T16394.stderr new file mode 100644 index 0000000000000000000000000000000000000000..fff51a6e39ed156a38c5c79e13324fa3ccf70825 --- /dev/null +++ b/testsuite/tests/typecheck/should_fail/T16394.stderr @@ -0,0 +1,5 @@ +T16394.hs:6:10: error: + Illegal class instance: ‘C a => C b => C (a, b)’ + Class instances must be of the form + context => C ty_1 ... ty_n + where ‘C’ is a class diff --git a/testsuite/tests/typecheck/should_fail/all.T b/testsuite/tests/typecheck/should_fail/all.T index b3c25eabe92ce3fc5f0d7f9d14cc9258ca224967..bd13b2f8cedc677e8530f93d310c0e34b9495b11 100644 --- a/testsuite/tests/typecheck/should_fail/all.T +++ b/testsuite/tests/typecheck/should_fail/all.T @@ -510,4 +510,5 @@ test('T16059e', [extra_files(['T16059b.hs'])], multimod_compile_fail, ['T16059e', '-v0']) test('T16255', normal, compile_fail, ['']) test('T16204c', normal, compile_fail, ['']) +test('T16394', normal, compile_fail, ['']) test('T16414', normal, compile_fail, [''])