#include<bits/stdc++.h>
using namespace std;
const int N=300005;
int n,m,a[N],b[N];
int read() {
int x=0,f=1; char c=getchar();
for(;c<'0'||c>'9';c=getchar()) if(c=='-') f=-1;
for(;c>='0'&&c<='9';c=getchar()) x=x*10+c-48;
return x*f;
}
void solve() {
n=read(); m=read();
for(int i=1;i<=n;i++) a[i]=read();
for(int i=1;i<=m;i++) b[i]=read();
sort(a+1,a+n+1,[](int x,int y){return x>y;});
sort(b+1,b+m+1,[](int x,int y){return x>y;});
int x=0;
for(int i=1;i<=m;i++) {
if(a[i]>b[i]) {puts("-1"); return ;}
x+=b[i]-a[i];
}
if(x>n-m) {puts("-1"); return ;}
x=n-m-x;
multiset<int> s,o;
vector<int> ans;
for(int i=1;i<=n;i++) s.insert(a[i]);
for(int i=1;i<=m;i++) for(int j=a[i];j<b[i];j++) o.insert(j);
while(x) {
int v=*s.begin();
ans.push_back(v);
s.erase(s.begin());
s.insert(v+1);
s.erase(s.begin());
if(o.find(v)!=o.end()) o.erase(o.find(v));
else {
x--;
if(v==b[m]) {puts("-1"); return ;}
}
}
for(int i:o) ans.push_back(i);
printf("%d\n",ans.size());
for(int i:ans) printf("%d ",i); puts("");
}
int main() {
for(int T=read();T--;) solve();
return 0;
}