#include <bits/stdc++.h>
using namespace std;
typedef long long int ll;
vector<ll> adj[1000001];
vector<ll> dfs_tree[1000001];
ll parent[1000001];
ll vis[1000001];
ll vis1[1000001];
ll disc[1000001];
ll low[1000001];
ll parent1[1000001];
ll counts[1000001];
ll counts2[1000001];
ll P=1000000007;
bool vis2[1000001],ap[1000001];
ll disc1[1000001];
ll low1[1000001];
ll parent2[1000001];
set<ll> articulations;
set<ll> dhundo;
ll visit[1000001];
ll times = 0;
set<pair<ll,ll>> se;
void bridges(ll src)
{
vis1[src]=1;
disc[src]=low[src]=++times;
for(ll i=0;i<adj[src].size();i++)
{
ll v=adj[src][i];
if(!vis1[v])
{
parent1[v]=src;
bridges(v);
low[src]=min(low[v],low[src]);
if (low[v] > disc[src])
{
if(se.find({v,src})!=se.end()||se.find({src,v})!=se.end())
{
}
else
{
// cout<<src<<" "<<v<<endl;
se.insert({src,v});
}
}
}
else if(v!=parent1[src])
{
low[src]=min(low[src], disc[v]);
}
}
}
void cheti_chand_dfs(ll src)
{
if(!vis[src])
{
vis[src]=1;
for(ll i=0;i<adj[src].size();i++)
{
if(!vis[adj[src][i]])
{
parent[adj[src][i]]=src;
dfs_tree[adj[src][i]].push_back(src);
dfs_tree[src].push_back(adj[src][i]);
cheti_chand_dfs(adj[src][i]);
}
}
}
}
void dfs(ll src)
{
if(!visit[src])
{
visit[src]=1;
for(ll i=0;i<adj[src].size();i++)
{
if(!visit[adj[src][i]])
{
dfs(adj[src][i]);
}
}
}
}
void count_nodes(ll src,ll e)
{
if(dhundo.find(src)!=dhundo.end())
counts[src]=1;
else
counts[src]=0;
counts2[src]=1;
for(ll i=0;i<dfs_tree[src].size();i++)
{
ll v=dfs_tree[src][i];
if(v==e)
{
continue;
}
count_nodes(v,src);
counts[src]+=counts[v];
counts2[src]+=counts2[v];
}
}
void artic(ll u)
{
ll children = 0;
vis2[u] = true;
disc1[u] = low1[u] = ++times;
for (ll i =0; i<adj[u].size();++i)
{
ll v = adj[u][i];
if (!vis2[v])
{
children++;
parent2[v] = u;
artic(v);
low1[u] = min(low1[u], low1[v]);
if (parent2[u] == 0 && children > 1)
{
ap[u] = true;
articulations.insert(u);
}
if (parent2[u] != 0 && low1[v] >= disc1[u])
{
ap[u] = true;
articulations.insert(u);
}
}
else if (v != parent2[u])
low1[u] = min(low1[u], disc1[v]);
}
}
int main()
{
ll i,j,k,l,m,n,o,p,q,r,s,t,x;
cin>>t;
while(t--)
{
cin>>n>>m>>x;
memset(vis,0,sizeof(ll)*(n+1));
memset(vis1,0,sizeof(ll)*(n+1));
memset(low,0,sizeof(ll)*(n+1));
memset(disc,0,sizeof(ll)*(n+1));
memset(parent,0,sizeof(ll)*(n+1));
memset(parent1,0,sizeof(ll)*(n+1));
memset(counts,0,sizeof(ll)*(n+1));
memset(vis2,false,sizeof(bool)*(n+1));
memset(parent2,0,sizeof(ll)*(n+1));
memset(disc1,0,sizeof(ll)*(n+1));
memset(low1,0,sizeof(ll)*(n+1));
memset(ap,false,sizeof(bool)*(n+1));
memset(counts2,0,sizeof(ll)*(n+1));
dhundo.clear();
se.clear();
articulations.clear();
for(i=1;i<=n;i++)
{
adj[i].clear();
dfs_tree[i].clear();
}
for(i=0;i<x;i++)
{
cin>>j;
dhundo.insert(j);
}
for(i=0;i<m;i++)
{
cin>>j>>k;
adj[j].push_back(k);
adj[k].push_back(j);
}
// if x is less than 100 applying dsu;
if(dhundo.size()==n)
{
cout<<0<<" "<<1<<"\n";
continue;
}
ll ma=0;
ll point=*(dhundo.begin());
if(n<=501)
{
for(auto it:dhundo)
{
memset(visit,0,sizeof(ll)*(n+1));
visit[it]=true;
for(i=1;i<=n;i++)
{
if(dhundo.find(i)!=dhundo.end())
{
if(!visit[i])
{
dfs(i);
}
}
}
ll xxx=0;
for(i=1;i<=n;i++)
{
if(!visit[i])
xxx++;
}
if(xxx>ma)
{
ma=xxx;
point=it;
}
}
cout<<ma<<" "<<point<<"\n";
// continue;
}
times=0;
cheti_chand_dfs(1);
times=0;
bridges(1);
times=0;
count_nodes(1,0);
times=0;
artic(1);
times=0;
for(i=1;i<=n;i++)
{
if(dhundo.find(i)!=dhundo.end())
{
if(1)
{
ll xx=0,yy=0;
ll zz=0,term=0;
ll flag=1;
if(se.find({parent1[i],i})!=se.end()||se.find({i,parent1[i]})!=se.end())
{
term=1;
if(counts[1]==counts[i])
{
zz+=counts2[1]-counts2[i];
}
}
if(counts[1]==counts[i])
{
xx=counts2[1]-counts2[i];
}
else
{
flag=0;
}
for(j=0;j<dfs_tree[i].size();j++)
{
if(se.find({i,dfs_tree[i][j]})!=se.end()||se.find({dfs_tree[i][j],i})!=se.end()||term==1)
{
if(dfs_tree[i][j]!=parent1[i])
{
if(counts[dfs_tree[i][j]]==0)
{
yy+=counts2[dfs_tree[i][j]];
}
}
else
{
}
}
else
{
if(dfs_tree[i][j]!=parent1[i])
{
if(counts[dfs_tree[i][j]]==0)
{
if(term==0)
xx+=counts2[dfs_tree[i][j]];
}
else
{
if(term==0)
flag=0;
}
}
}
}
if(zz+yy>ma)
{
ma=zz+yy;
point=i;
}
if(flag==1)
{
yy+=xx;
}
if(ma<yy)
{
ma=yy;
point=i;
}
}
}
}
cout<<ma<<" "<<point<<endl;
}
return 0;
}
#include <bits/stdc++.h>
using namespace std;
typedef long long int ll;
vector<ll> adj[1000001];
vector<ll> dfs_tree[1000001];
ll parent[1000001];
ll vis[1000001];
ll vis1[1000001];
ll disc[1000001];
ll low[1000001];
ll parent1[1000001];
ll counts[1000001];
ll counts2[1000001];
ll P=1000000007;
bool vis2[1000001],ap[1000001];
ll disc1[1000001];
ll low1[1000001];
ll parent2[1000001];
set<ll> articulations;
set<ll> dhundo;
ll visit[1000001];
 ll times = 0;
        set<pair<ll,ll>> se;
        void bridges(ll src)
        {
            vis1[src]=1;
            disc[src]=low[src]=++times;
            for(ll i=0;i<adj[src].size();i++)
            {
                ll v=adj[src][i];
                if(!vis1[v])
                {
                    parent1[v]=src;
                    bridges(v);
                    low[src]=min(low[v],low[src]);
                    if (low[v] > disc[src])
                    {
                        if(se.find({v,src})!=se.end()||se.find({src,v})!=se.end())
                        {
         
                        }
                        else 
                        {
                           // cout<<src<<" "<<v<<endl;
                            se.insert({src,v});
                        }
                    } 
                }
                else if(v!=parent1[src])
                {
                     low[src]=min(low[src], disc[v]); 
                }
            }
        }
        void cheti_chand_dfs(ll src)
        {
            if(!vis[src])
            {
            vis[src]=1;
            for(ll i=0;i<adj[src].size();i++)
            {
                if(!vis[adj[src][i]])
                {
                    parent[adj[src][i]]=src;
                    dfs_tree[adj[src][i]].push_back(src);
                    dfs_tree[src].push_back(adj[src][i]);
                    cheti_chand_dfs(adj[src][i]);
                }
            }
            }
        }
        void dfs(ll src)
        {
            if(!visit[src])
            {
            visit[src]=1;
            for(ll i=0;i<adj[src].size();i++)
            {
                if(!visit[adj[src][i]])
                {
                    dfs(adj[src][i]);
                }
            }
            }
        }
        void count_nodes(ll src,ll e)
        {
            if(dhundo.find(src)!=dhundo.end())
            counts[src]=1;
            else 
            counts[src]=0;
            counts2[src]=1;
            for(ll i=0;i<dfs_tree[src].size();i++)
            {
                ll v=dfs_tree[src][i];
                if(v==e)
                {
                    continue;
                }
                count_nodes(v,src);
               counts[src]+=counts[v];
               counts2[src]+=counts2[v];
            }
        }  

 void artic(ll u)
 {
    ll children = 0; 
    vis2[u] = true; 
    disc1[u] = low1[u] = ++times; 
    for (ll i =0; i<adj[u].size();++i) 
    { 
        ll v = adj[u][i];
        if (!vis2[v]) 
        { 
            children++; 
            parent2[v] = u; 
            artic(v); 
            low1[u]  = min(low1[u], low1[v]); 
            if (parent2[u] == 0 && children > 1)
            {
               ap[u] = true;
               articulations.insert(u); 
            } 
            if (parent2[u] != 0 && low1[v] >= disc1[u]) 
            {
                 ap[u] = true; 
                articulations.insert(u);
            } 
        } 
        else if (v != parent2[u]) 
            low1[u]  = min(low1[u], disc1[v]); 
    } 
 }
        int main()
        {
            ll i,j,k,l,m,n,o,p,q,r,s,t,x;
            cin>>t;
            while(t--)
            {
            cin>>n>>m>>x;
            memset(vis,0,sizeof(ll)*(n+1));
            memset(vis1,0,sizeof(ll)*(n+1));
            memset(low,0,sizeof(ll)*(n+1));
            memset(disc,0,sizeof(ll)*(n+1));
            memset(parent,0,sizeof(ll)*(n+1));
            memset(parent1,0,sizeof(ll)*(n+1));
            memset(counts,0,sizeof(ll)*(n+1));
            memset(vis2,false,sizeof(bool)*(n+1));
            memset(parent2,0,sizeof(ll)*(n+1));
            memset(disc1,0,sizeof(ll)*(n+1));
            memset(low1,0,sizeof(ll)*(n+1));
            memset(ap,false,sizeof(bool)*(n+1));
            memset(counts2,0,sizeof(ll)*(n+1));
            dhundo.clear();
            se.clear();
            articulations.clear();
             for(i=1;i<=n;i++)
             {
                 adj[i].clear();
                 dfs_tree[i].clear();
             }
            for(i=0;i<x;i++)
            {
                cin>>j;
                dhundo.insert(j);
            }
            for(i=0;i<m;i++)
            {
                cin>>j>>k;
                adj[j].push_back(k);
                adj[k].push_back(j);
            } 

           

            // if x is less than 100 applying dsu;
             if(dhundo.size()==n)
             {
                 cout<<0<<" "<<1<<"\n";
                 continue;
             }
            ll ma=0;
           ll point=*(dhundo.begin());
           if(n<=501)
           {
               for(auto it:dhundo)
            {
                memset(visit,0,sizeof(ll)*(n+1));
                visit[it]=true;
                for(i=1;i<=n;i++)
                {
                   if(dhundo.find(i)!=dhundo.end())
                   {
                       if(!visit[i])
                       {
                           dfs(i);
                       }
                   }
                }
                ll xxx=0;
                for(i=1;i<=n;i++)
                {
                    if(!visit[i])
                    xxx++;
                }
                if(xxx>ma)
                {
                    ma=xxx;
                    point=it;
                }
            }
            cout<<ma<<" "<<point<<"\n";
          //  continue;
           }
            

            times=0;
            cheti_chand_dfs(1);
            times=0;
            bridges(1);
          times=0;
            count_nodes(1,0);
          times=0;
           artic(1);
             times=0;
          
           for(i=1;i<=n;i++)
           {
               
               if(dhundo.find(i)!=dhundo.end())
               {
                   if(1)
                   {
                       ll xx=0,yy=0;
                       ll zz=0,term=0;
                       ll flag=1;
    if(se.find({parent1[i],i})!=se.end()||se.find({i,parent1[i]})!=se.end())
    {
        term=1;
        if(counts[1]==counts[i])
        {
            zz+=counts2[1]-counts2[i];
        }
    }
                       if(counts[1]==counts[i])
                       {
                           xx=counts2[1]-counts2[i];
                       }
                       else 
                       {
                          flag=0;
                       }
                       for(j=0;j<dfs_tree[i].size();j++)
                       {
if(se.find({i,dfs_tree[i][j]})!=se.end()||se.find({dfs_tree[i][j],i})!=se.end()||term==1)
        {
            if(dfs_tree[i][j]!=parent1[i])
            {
                if(counts[dfs_tree[i][j]]==0)
                {
                    yy+=counts2[dfs_tree[i][j]];
                }
            }
            else 
            {

            }
       }
             else
             {
             if(dfs_tree[i][j]!=parent1[i])
             {
                if(counts[dfs_tree[i][j]]==0)
                {
                    if(term==0)
                    xx+=counts2[dfs_tree[i][j]];
                }
                else
                {
                    if(term==0)
                    flag=0;
                }
             }
            }     
                       }
                        if(zz+yy>ma)
                        {
                            ma=zz+yy;
                            point=i;
                        }
                       if(flag==1)
                       {
                           yy+=xx;
                       }
                        if(ma<yy)
                        {
                            ma=yy;
                            point=i;
                        }
                       
                   }
               }
           }
            cout<<ma<<" "<<point<<endl;
            }
            return 0;
        }
