struct node
{
int x,y;
}p[N],a[N];
int n,tot;
double dis(node a,node b)
{
return hypot(a.x-b.x,a.y-b.y);
}
int multi(node p0,node p1,node p2)
{
return (p1.x-p0.x)*(p2.y-p0.y)-(p2.x-p0.x)*(p1.y-p0.y);
}
int cmp(node a,node b)
{
int x=multi(a,b,p[0]);
if(x>0||(x==0)&&dis(a,p[0])<dis(b,p[0])) return 1;
return 0;
}
void Graham()
{
int k=0;
for(int i=1;i<n;i++)
if(p[i].y<p[k].y||(p[i].y==p[k].y&&p[i].x<p[k].x)) k=i;
swap(p[0],p[k]);
sort(p+1,p+n,cmp);
tot=2,a[0]=p[0],a[1]=p[1];
for(int i=2;i<n;i++)
{
while(tot>1&&multi(p[i],a[tot-1],a[tot-2])>=0) tot--;
a[tot++]=p[i];
}
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(int i=0;i<n;i++)
scanf("%d%d",&p[i].x,&p[i].y);
Graham();
}
return 0;
}