#include <bits/stdc++.h>
#define ll long long
#define PI 3.14159265359
#define DP(x, y) memset(x, y, sizeof x)
#define all(x) x.begin(), x.end()
#define read(x) freopen("x", "r", stdin);
#define write(x) freopen("x", "w", stdout);
using namespace std;
ll gcd(ll a,ll b) { while(b) { ll x = a; a = b; b = x % b; } return a; }
ll lcm(ll a,ll b) { return a / gcd(a, b) * b; }
ll nC2(ll n) { return (n)*(n-1)/2; }
ll summing(ll n) { return (n)*(n+1); }
int Paths(int i, int j, int n, int m, vector<vector<char>>&grid, vector<vector<bool>>&vis, vector<vector<int>>&dp) {
if (i == n && j == m) {
return 1;
}
if (i > n || j > m || i == 0 || j == 0) {
return 0;
}
if ( grid[i][j] == '*' || vis[i][j] ) {
return 0;
}
if (~dp[i][j]) {
return dp[i][j];
}
vis[i][j] = 1;
int x = Paths(i+1, j, n, m, grid, vis, dp);
int y = Paths(i, j+1, n, m, grid, vis, dp);
vis[i][j] = 0;
return (dp[i][j] = x+y);
}
void solve() {
int n,m; cin >> n >> m;
vector<pair<int,int>> breaking;
vector<vector<char>> grid(n+1, vector<char>(m+1, '.'));
vector<vector<bool>> vis(n+1, vector<bool>(m+1, 0));
vector<vector<int>> dp(n+1, vector<int>(m+1, -1));
cin.ignore();
for (int i=0; i<n; i++) {
string s, row, col;
getline(cin, s);
stringstream ss(s);
ss >> row;
while (ss >> col) {
breaking.push_back({stoi(row), stoi(col)});
}
}
for (auto i:breaking) {
grid[i.first][i.second] = '*';
}
cout << Paths(1,1,n,m,grid,vis,dp) << "\n\n";
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(nullptr), cout.tie(nullptr);
ll t=1; cin >> t;
while (t--) { solve(); }
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNkZWZpbmUgbGwgbG9uZyBsb25nCiNkZWZpbmUgUEkgMy4xNDE1OTI2NTM1OQojZGVmaW5lIERQKHgsIHkpIG1lbXNldCh4LCB5LCBzaXplb2YgeCkKI2RlZmluZSBhbGwoeCkgeC5iZWdpbigpLCB4LmVuZCgpCiNkZWZpbmUgcmVhZCh4KSBmcmVvcGVuKCJ4IiwgInIiLCBzdGRpbik7CiNkZWZpbmUgd3JpdGUoeCkgZnJlb3BlbigieCIsICJ3Iiwgc3Rkb3V0KTsKCnVzaW5nIG5hbWVzcGFjZSBzdGQ7CgpsbCBnY2QobGwgYSxsbCBiKSB7IHdoaWxlKGIpIHsgbGwgeCA9IGE7IGEgPSBiOyBiID0geCAlIGI7IH0gcmV0dXJuIGE7IH0KbGwgbGNtKGxsIGEsbGwgYikgeyByZXR1cm4gYSAvIGdjZChhLCBiKSAqIGI7IH0KbGwgbkMyKGxsIG4pIHsgcmV0dXJuIChuKSoobi0xKS8yOyB9CmxsIHN1bW1pbmcobGwgbikgeyByZXR1cm4gKG4pKihuKzEpOyB9CgppbnQgUGF0aHMoaW50IGksIGludCBqLCBpbnQgbiwgaW50IG0sIHZlY3Rvcjx2ZWN0b3I8Y2hhcj4+JmdyaWQsIHZlY3Rvcjx2ZWN0b3I8Ym9vbD4+JnZpcywgdmVjdG9yPHZlY3RvcjxpbnQ+PiZkcCkgewoKICAgIGlmIChpID09IG4gJiYgaiA9PSBtKSB7CiAgICAgICAgcmV0dXJuIDE7CiAgICB9CiAgICBpZiAoaSA+IG4gfHwgaiA+IG0gfHwgaSA9PSAwIHx8IGogPT0gMCkgewogICAgICAgIHJldHVybiAwOwogICAgfQogICAgaWYgKCBncmlkW2ldW2pdID09ICcqJyB8fCB2aXNbaV1bal0gKSB7CiAgICAgICAgcmV0dXJuIDA7CiAgICB9CiAgICBpZiAofmRwW2ldW2pdKSB7CiAgICAgICAgcmV0dXJuIGRwW2ldW2pdOwogICAgfQoKICAgIHZpc1tpXVtqXSA9IDE7CiAgICBpbnQgeCA9IFBhdGhzKGkrMSwgaiwgbiwgbSwgZ3JpZCwgdmlzLCBkcCk7CiAgICBpbnQgeSA9IFBhdGhzKGksIGorMSwgbiwgbSwgZ3JpZCwgdmlzLCBkcCk7CiAgICB2aXNbaV1bal0gPSAwOwoKICAgIHJldHVybiAoZHBbaV1bal0gPSB4K3kpOwoKfQoKdm9pZCBzb2x2ZSgpIHsKCiAgICBpbnQgbixtOyBjaW4gPj4gbiA+PiBtOwoKICAgIHZlY3RvcjxwYWlyPGludCxpbnQ+PiBicmVha2luZzsKICAgIHZlY3Rvcjx2ZWN0b3I8Y2hhcj4+IGdyaWQobisxLCB2ZWN0b3I8Y2hhcj4obSsxLCAnLicpKTsKICAgIHZlY3Rvcjx2ZWN0b3I8Ym9vbD4+IHZpcyhuKzEsIHZlY3Rvcjxib29sPihtKzEsIDApKTsKCiAgICB2ZWN0b3I8dmVjdG9yPGludD4+IGRwKG4rMSwgdmVjdG9yPGludD4obSsxLCAtMSkpOwoKICAgIGNpbi5pZ25vcmUoKTsKCiAgICBmb3IgKGludCBpPTA7IGk8bjsgaSsrKSB7CgogICAgICAgIHN0cmluZyBzLCByb3csIGNvbDsKICAgICAgICBnZXRsaW5lKGNpbiwgcyk7CgogICAgICAgIHN0cmluZ3N0cmVhbSBzcyhzKTsKCiAgICAgICAgc3MgPj4gcm93OwoKICAgICAgICB3aGlsZSAoc3MgPj4gY29sKSB7CiAgICAgICAgICAgIGJyZWFraW5nLnB1c2hfYmFjayh7c3RvaShyb3cpLCBzdG9pKGNvbCl9KTsKICAgICAgICB9CiAgICB9CgogICAgZm9yIChhdXRvIGk6YnJlYWtpbmcpIHsKICAgICAgICBncmlkW2kuZmlyc3RdW2kuc2Vjb25kXSA9ICcqJzsKICAgIH0KCiAgICBjb3V0IDw8IFBhdGhzKDEsMSxuLG0sZ3JpZCx2aXMsZHApIDw8ICJcblxuIjsKCn0KCmludCBtYWluKCkKewogICAgaW9zOjpzeW5jX3dpdGhfc3RkaW8oZmFsc2UpOwogICAgY2luLnRpZShudWxscHRyKSwgY291dC50aWUobnVsbHB0cik7CgogICAgbGwgdD0xOyBjaW4gPj4gdDsKICAgIHdoaWxlICh0LS0pIHsgc29sdmUoKTsgfQoKICAgIHJldHVybiAwOwp9Cg==