#include <bits/stdc++.h>
using namespace std;
bool isSorted(const std::vector<int>& vec) {
for (int i = 0; i < vec.size() - 1; i++) {
if (vec[i] > vec[i + 1]) {
return false;
}
}
return true;
}
#define LL long long
const int MOD = 1000000007;
LL modPow(LL base, LL exponent) {
if (exponent == 0) {
return 1;
}
LL result = 1;
base = base % MOD;
for (int i = 0; i < exponent; ++i) {
result = (result * base) % MOD;
}
return result;
}
void solve() {
int n;
cin >> n;
vector<int> a(n + 1, -1);
for (int i = 1; i <= n; ++i) {
cin >> a[i];
}
vector<int> b(n + 1, 0);
for (int i = 1; i <= n; ++i) {
b[i] = i;
}
int ans = 0;
// perform operations
while (ans == 0 || !isSorted(b)) {
ans++;
vector<int> new_b(n + 1, -1);
for (int i = 1; i <= n; ++i) {
new_b[i] = b[a[i]];
}
b = new_b;
}
cout << modPow(2, ans) << endl;
}
int main() {
int t;
cin >> t;
while (t--) {
solve();
}
}