#include<iostream>#include<cstring>#include<algorithm>#include<string>usingnamespace std;constint N =1e6+10;int n, m;int ne[N];char s[N], p[N];intmain(){int T;scanf("%d",&T);while(T--){scanf("%s%s", s +1, p +1);int n =strlen(s +1);int m =strlen(p +1);for(int i =2, j =0; i <= n; i++){while(j && s[i]!= s[j +1])
j = ne[j];if(s[i]== s[j +1])
j++;
ne[i]= j;}int f =0;for(int i =1, j =0; i <= m; i++){while(j && p[i]!= s[j +1])
j = ne[j];if(p[i]== s[j +1])
j++;if(!j){printf("NO\n");
f =1;break;}}if(!f)printf("YES\n");for(int i =1; i <= n; i++)
ne[i]=0;}}