¿Qué SFINAE no funciona correctamente con la siguiente función has_member?

Estoy probando ejemplos deCharla TMP de Walter Brown y estoy tratando de conseguir suhas_member implementación de trabajo.

Sin embargo, la implementación parece falsamente cierta, lo que me lleva a creer que hay algunos detalles de SFINAE que no entiendo.

#include <iostream>
#include <type_traits>

template <class ...>
using void_t = void;

template <class, class = void>
struct has_type_member: std::false_type {};

template <class T> 
struct has_type_member<T, void_t<typename T::type> >: std::true_type {};

struct FooWithType
{
    typedef int type;
};

struct FooNoType 
{
};

int main()
{
    std::cout << "Does FooWithType have type member? " << 
        (has_type_member<FooWithType>() ? "YES" : "NO") << "\n";

    std::cout << "Does FooNoType have type member? " << 
        (has_type_member<FooNoType>() ? "YES" : "NO") << "\n";

    return 1;                                                                                                                 
}      

Salida es:

Does FooWithType have type member? YES
Does FooNoType have type member? YES

Estoy en gcc 4.8.2 en Ubuntu.