#include<bits/stdc++.h>
using namespace std;
// define
#define execute cerr << " Time: " << fixed << setprecision(6) << (1.0 * clock() / CLOCKS_PER_SEC) << "s\n";
#define ll long long
#define ii pair <int , int>
#define iii pair <int , ii>
#define se second
#define fi first
#define all(v) (v).begin() , (v).end()
#define Unique(v) sort(all(v)) , v.resize(unique(all(v)) - v.begin())
#define bit(x,i) (((x) >> (i)) & 1LL)
#define flip(x,i) ((x) ^ (1LL << (i)))
#define ms(d,x) memset(d , x , sizeof(d))
#define exist __exist
#define ends __ends
#define visit visited
#define left __left
#define right __right
#define prev __prev
#define next __next
#define sitingfake 1
#define orz 1
//constant
const long long mod = 1e9 + 7;
const long long linf = 4557430888798830399LL;
const long long nlinf = -4485090715960753727LL;
const int inf = 1061109567;
const int ninf = -1044266559;
const int dx[] = {0 , -1 , 0 , 1};
const int dy[] = {-1 , 0 , 1 , 0};
template<typename T> bool maximize(T &a, const T &b)
{
if(a < b) {a = b; return 1;}
return 0;
}
template<typename T> bool minimize(T &a, const T &b)
{
if(a > b) {a = b; return 1;}
return 0;
}
void Plus(ll & a ,ll b)
{
b %= mod;
a += b;
if(a < 0) a += mod;
a %= mod;
return;
}
void Mul(ll & a, ll b)
{
(a *= (b % mod)) %= mod;
return;
}
//code
const int maxn = 303;
vector <int> g[maxn];
int n , m;
bool d[maxn];
bool edges[maxn][maxn];
void reset()
{
for(int i = 1; i <= n; i++)
{
d[i] = 0;
g[i].clear();
}
for(int i = 1; i <= n; i++)
{
for(int j = 1; j <= n; j++)
{
edges[i][j] = 0;
}
}
}
void solve(void)
{
reset();
cin >> n >> m;
for(int i = 1; i <= m; i++)
{
int u , v;
cin >> u >> v;
if(u > v) swap(u , v);
g[u].push_back(v);
g[v].push_back(u);
edges[u][v] = edges[v][u] = 1;
}
if(n < 5)
{
cout << -1 << "\n";
return;
}
for(int i = 1; i <= n; i++) sort(all(g[i]));
for(int i = 1; i <= n; i++)
{
bool flag = 0;
for(int v : g[i]) d[v] = 1;
for(int v : g[i])
{
for(int w : g[v])
{
if(d[w])
{
flag = 1;
break;
}
}
if(flag) break;
}
for(int v : g[i]) d[v] = 0;
if(flag)
{
for(int u = 1; u <= n; u++)
{
for(int v = u + 1; v <= n; v++)
{
if(u != i && v != i && !edges[u][v] && !edges[v][i] && !edges[i][u])
{
cout << "5\n";
return;
}
}
}
}
}
cout << -1 << "\n";
}
/**
**/
signed main()
{
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
#define task "triple"
if(fopen(task".inp","r"))
{
freopen(task".inp","r",stdin);
freopen(task".out","w",stdout);
}
int tc = 1;
cin >> tc;
while(tc--) solve();
// execute;
}
I2luY2x1ZGU8Yml0cy9zdGRjKysuaD4KdXNpbmcgbmFtZXNwYWNlIHN0ZDsKCi8vIGRlZmluZQoKI2RlZmluZSBleGVjdXRlIGNlcnIgPDwgIiBUaW1lOiAiIDw8IGZpeGVkIDw8IHNldHByZWNpc2lvbig2KSA8PCAoMS4wICogY2xvY2soKSAvIENMT0NLU19QRVJfU0VDKSA8PCAic1xuIjsKI2RlZmluZSBsbCBsb25nIGxvbmcKI2RlZmluZSBpaSBwYWlyIDxpbnQgLCBpbnQ+CiNkZWZpbmUgaWlpIHBhaXIgPGludCAsIGlpPgojZGVmaW5lIHNlIHNlY29uZAojZGVmaW5lIGZpIGZpcnN0CiNkZWZpbmUgYWxsKHYpICh2KS5iZWdpbigpICwgKHYpLmVuZCgpCiNkZWZpbmUgVW5pcXVlKHYpIHNvcnQoYWxsKHYpKSAsIHYucmVzaXplKHVuaXF1ZShhbGwodikpIC0gdi5iZWdpbigpKQojZGVmaW5lIGJpdCh4LGkpICgoKHgpID4+IChpKSkgJiAxTEwpCiNkZWZpbmUgZmxpcCh4LGkpICgoeCkgXiAoMUxMIDw8IChpKSkpCiNkZWZpbmUgbXMoZCx4KSBtZW1zZXQoZCAsIHggLCBzaXplb2YoZCkpCiNkZWZpbmUgZXhpc3QgX19leGlzdAojZGVmaW5lIGVuZHMgX19lbmRzCiNkZWZpbmUgdmlzaXQgdmlzaXRlZAojZGVmaW5lIGxlZnQgX19sZWZ0CiNkZWZpbmUgcmlnaHQgX19yaWdodAojZGVmaW5lIHByZXYgX19wcmV2CiNkZWZpbmUgbmV4dCBfX25leHQKI2RlZmluZSBzaXRpbmdmYWtlIDEKI2RlZmluZSBvcnogMQovL2NvbnN0YW50Cgpjb25zdCBsb25nIGxvbmcgbW9kID0gMWU5ICsgNzsKY29uc3QgbG9uZyBsb25nIGxpbmYgPSA0NTU3NDMwODg4Nzk4ODMwMzk5TEw7CmNvbnN0IGxvbmcgbG9uZyBubGluZiA9IC00NDg1MDkwNzE1OTYwNzUzNzI3TEw7CmNvbnN0IGludCBpbmYgPSAxMDYxMTA5NTY3Owpjb25zdCBpbnQgbmluZiA9IC0xMDQ0MjY2NTU5Owpjb25zdCBpbnQgZHhbXSA9IHswICwgLTEgLCAwICwgMX07CmNvbnN0IGludCBkeVtdID0gey0xICwgMCAsIDEgLCAwfTsKCnRlbXBsYXRlPHR5cGVuYW1lIFQ+IGJvb2wgbWF4aW1pemUoVCAmYSwgY29uc3QgVCAmYikKewogICAgaWYoYSA8IGIpIHthID0gYjsgcmV0dXJuIDE7fQogICAgcmV0dXJuIDA7Cn0KCnRlbXBsYXRlPHR5cGVuYW1lIFQ+IGJvb2wgbWluaW1pemUoVCAmYSwgY29uc3QgVCAmYikKewogICAgaWYoYSA+IGIpIHthID0gYjsgcmV0dXJuIDE7fQogICAgcmV0dXJuIDA7Cn0KCnZvaWQgUGx1cyhsbCAmIGEgLGxsIGIpCnsKICAgIGIgJT0gbW9kOwogICAgYSArPSBiOwogICAgaWYoYSA8IDApIGEgKz0gbW9kOwogICAgYSAlPSBtb2Q7CiAgICByZXR1cm47Cn0KCnZvaWQgTXVsKGxsICYgYSwgbGwgYikKewogICAgKGEgKj0gKGIgJSBtb2QpKSAlPSBtb2Q7CiAgICByZXR1cm47Cn0KCi8vY29kZQpjb25zdCBpbnQgbWF4biA9IDMwMzsKdmVjdG9yIDxpbnQ+IGdbbWF4bl07CmludCBuICwgbTsKYm9vbCBkW21heG5dOwpib29sIGVkZ2VzW21heG5dW21heG5dOwp2b2lkIHJlc2V0KCkKewogICAgZm9yKGludCBpID0gMTsgaSA8PSBuOyBpKyspCiAgICB7CiAgICAgICAgZFtpXSA9IDA7CiAgICAgICAgZ1tpXS5jbGVhcigpOwogICAgfQogICAgZm9yKGludCBpID0gMTsgaSA8PSBuOyBpKyspCiAgICB7CiAgICAgICAgZm9yKGludCBqID0gMTsgaiA8PSBuOyBqKyspCiAgICAgICAgewogICAgICAgICAgICBlZGdlc1tpXVtqXSA9IDA7CiAgICAgICAgfQogICAgfQp9CnZvaWQgc29sdmUodm9pZCkKewogICAgcmVzZXQoKTsKICAgIGNpbiA+PiBuID4+IG07CgogICAgZm9yKGludCBpID0gMTsgaSA8PSBtOyBpKyspCiAgICB7CiAgICAgICAgaW50IHUgLCB2OwogICAgICAgIGNpbiA+PiB1ID4+IHY7CiAgICAgICAgaWYodSA+IHYpIHN3YXAodSAsIHYpOwogICAgICAgIGdbdV0ucHVzaF9iYWNrKHYpOwogICAgICAgIGdbdl0ucHVzaF9iYWNrKHUpOwogICAgICAgIGVkZ2VzW3VdW3ZdID0gZWRnZXNbdl1bdV0gPSAxOwogICAgfQogICAgaWYobiA8IDUpCiAgICB7CiAgICAgICAgY291dCA8PCAtMSA8PCAiXG4iOwogICAgICAgIHJldHVybjsKICAgIH0KICAgIGZvcihpbnQgaSA9IDE7IGkgPD0gbjsgaSsrKSBzb3J0KGFsbChnW2ldKSk7CiAgICBmb3IoaW50IGkgPSAxOyBpIDw9IG47IGkrKykKICAgIHsKICAgICAgICBib29sIGZsYWcgPSAwOwogICAgICAgIGZvcihpbnQgdiA6IGdbaV0pIGRbdl0gPSAxOwogICAgICAgIGZvcihpbnQgdiA6IGdbaV0pCiAgICAgICAgewogICAgICAgICAgICBmb3IoaW50IHcgOiBnW3ZdKQogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICBpZihkW3ddKQogICAgICAgICAgICAgICAgewogICAgICAgICAgICAgICAgICAgIGZsYWcgPSAxOwogICAgICAgICAgICAgICAgICAgIGJyZWFrOwogICAgICAgICAgICAgICAgfQogICAgICAgICAgICB9CiAgICAgICAgICAgIGlmKGZsYWcpIGJyZWFrOwogICAgICAgIH0KICAgICAgICBmb3IoaW50IHYgOiBnW2ldKSBkW3ZdID0gMDsKICAgICAgICBpZihmbGFnKQogICAgICAgIHsKICAgICAgICAgICAgZm9yKGludCB1ID0gMTsgdSA8PSBuOyB1KyspCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIGZvcihpbnQgdiA9IHUgKyAxOyB2IDw9IG47IHYrKykKICAgICAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgICAgICBpZih1ICE9IGkgJiYgdiAhPSBpICYmICFlZGdlc1t1XVt2XSAmJiAhZWRnZXNbdl1baV0gJiYgIWVkZ2VzW2ldW3VdKQogICAgICAgICAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgICAgICAgICAgY291dCA8PCAiNVxuIjsKICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuOwogICAgICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgfQogICAgICAgIH0KICAgIH0KICAgIGNvdXQgPDwgLTEgPDwgIlxuIjsKfQovKioKKiovCnNpZ25lZCBtYWluKCkKewogICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKDApOwogICBjaW4udGllKDApOwogICBjb3V0LnRpZSgwKTsKCiAgICNkZWZpbmUgdGFzayAidHJpcGxlIgoKICAgaWYoZm9wZW4odGFzayIuaW5wIiwiciIpKQogICB7CiAgICAgICBmcmVvcGVuKHRhc2siLmlucCIsInIiLHN0ZGluKTsKICAgICAgIGZyZW9wZW4odGFzayIub3V0IiwidyIsc3Rkb3V0KTsKICAgfQoKICAgaW50IHRjID0gMTsKICAgY2luID4+IHRjOwogICB3aGlsZSh0Yy0tKSBzb2x2ZSgpOwoKLy8gICBleGVjdXRlOwp9Cg==