#include<bits/stdc++.h>
#define endl '\n'
#define INF 0x3f3f3f3f
#define ll long long
using namespace std;
typedef pair<int,int> PII;
const int N=550;
struct node
{
int v,w,va;//双重元素最短路问题
};
vector<node> g[N];
int dist[N];
int value[N];
bool vis[N];
int n,m,s,t,T;
void init()
{
for(int i=0;i<=n;i++)
{
g[i].clear();
dist[i]=INF;
vis[i]=false;
value[i]=INF;
}
}
void dijkstra()
{
dist[s]=value[s]=0;
priority_queue<PII,vector<PII>,greater<PII>> q;
q.push({dist[s],s});
while(q.size())
{
int u=q.top().second;
q.pop();
if(vis[u])continue;
vis[u]=true;
for(auto [v,w,va]:g[u])
{
if(dist[v]>dist[u]+w)//优先比较路径
{
dist[v]=dist[u]+w;
value[v]=value[u]+va;
q.push({dist[v],v});
}
else if(dist[v]==dist[u]+w)//若路径相同
{
if(value[v]>value[u]+va)//再比较费用
{
value[v]=value[u]+va;
q.push({dist[v],v});
}
}
}
}
}
void solve()
{
cin>>n>>m>>s>>t;
init();
for(int i=0;i<m;i++)
{
int u,v,w,va;
cin>>u>>v>>w>>va;
g[u].push_back({v,w,va});
g[v].push_back({u,w,va});
}
dijkstra();
cout<<dist[t]<<" "<<value[t]<<endl;
}
int main()
{
cin>>T;
while(T--)
{
solve();
}
return 0;
}