import java.io.*;
import java.math.*;
import java.util.*;
/*
yash jobanputra
DA-IICT
*/
class mstkp {
private static byte[] buf = new byte[1024];
private static int curChar;
private static int numChars;
private static SpaceCharFilter filter;
private static long mod = 1000000000 + 7;
private static long mod1 = 1000000000 + 9;
private static int MAX=1000001;
private static int block;
private static int count;
private static boolean[] vis;
private static Stack<Integer> st;
private static int times=0;
public static int cc;
public static int pos;
private static void soln(){
int t=ni();
for(int c=0;c<t;c++)
{
int n=ni();
int[][] ecost=new int[n+1][n+1];
for(int i=0;i<=n;i++)
{
tree[i]=new ArrayList<>();
}
for(int i=1;i<n;i++)
{
int a=ni();int b=ni();int cost=ni();
tree[a].add(new Pair(b,i));
tree[b].add(new Pair(a,i));
ecost[a][b]=cost;
ecost[b][a]=cost;
}
hld.initial(n);
hld.dfs(1, 1, tree);
hld.ilca(n);
hld.Hld(1, 0, -1, tree, ecost);
hld.build(1, 1, pos);
while(true)
{
if(s[0].contentEquals("DONE"))
break;
else if(s[0].contentEquals("QUERY"))
pw.
println(hld.
querypath(Integer.
parseInt(s
[1]),
Integer.
parseInt(s
[2]))); else
}
}
}
public static class hld
{
static int[][] p;static int[] dp;static int[] subsize;static int[] endnode;static int chainno;static int[] chainhead,chainind,arrpos,costarr,segtree;
public static void initial(int n)
{
p=new int[n+1][22];
dp=new int[n+1];
subsize=new int[n+1];
endnode=new int[n];
chainhead=new int[n+1];
chainind=new int[n+1];
arrpos=new int[n+1];
costarr=new int[n];
segtree=new int[n*4];
chainno=1;
pos=-1;
}
public static void ilca(int n)
{
for(int i=1;i<=n;i++)
{
for(int j=1;j<22;j++)
p[i][j]=-1;
}
for(int j=1;1<<j<=n;j++)
{
for(int i=1;i<=n;i++)
{
if(p[i][j-1]!=-1)
p[i][j]=p[p[i][j-1]][j-1];
}
}
}
public static void dfs(int node,int par,ArrayList<Pair>[] tree)
{
if(par==0) dp[node]=0;
subsize[node]=1;
p[node][0]=par;
for(int i=0;i<tree[node].size();i++)
{
int next=tree[node].get(i).v;
int ind=tree[node].get(i).i;
if(next!=par)
{
endnode[ind]=next;
dfs(next,node,tree);
subsize[node]+=subsize[next];
}
}
}
public static int lca(int u,int v)
{
if(dp[u]<dp[v])
{
int temp=u;
u=v;
v=temp;
}
int log;
for (log = 1; 1 << log <= dp[u]; log++);
log--;
for(int i=log;i>=0;i--)
{
if(dp[u]-(1<<i)>=dp[v])
u=p[u][i];
}
if(u==v)
return u;
for(int i=log;i>=0;i--)
{
if(p[u][i]!=-1 && p[u][i]!=p[v][i])
{u=p[u][i];v=p[v][i];}
}
return p[u][0];
}
public static void Hld(int node,int cost,int par,ArrayList<Pair>[] tree,int[][] ecost)
{
if(chainhead[chainno]==-1) chainhead[chainno]=node;
pos++;
chainind[node]=chainno;
costarr[pos]=cost;
arrpos[node]=pos;
int hn=-1;int hc=0;
for(int i=0;i<tree[node].size();i++)
{
int next=tree[node].get(i).v;
if((next!=par)&&(hn==-1 || subsize[next]>subsize[hn]))
{
hn=next;
hc=ecost[node][next];
}
}
if(hn!=-1)
Hld(hn,hc,node,tree,ecost);
for(int i=0;i<tree[node].size();i++)
{
int next=tree[node].get(i).v;
if(next!=par && next!=hn)
{
chainno++;
Hld(next,ecost[node][next],node,tree,ecost);
}
}
}
public static void build(int node,int l,int r)
{
if(l==r)
{
segtree[node]=costarr[l];
}
else
{
int m=(l+r)/2;
build((2*node),l,m);
build((2*node)+1,m+1,r);
segtree
[node
]=Math.
max(segtree
[2*node
],segtree
[2*node
+1]); }
}
public static void update(int node,int l,int r,int ind,int val)
{
if(l==r)
{
costarr[ind]=val;
segtree[node]=val;
}
else
{
int m=(l+r)/2;
if(l<=ind && ind<=m)
{
update((2*node),l,m,ind,val);
}
else
{
update((2*node+1),m+1,r,ind,val);
}
segtree
[node
]=Math.
max(segtree
[2*node
], segtree
[2*node
+1]); }
}
public static int query(int node,int l,int r,int s,int e)
{
if(e<l || r<s)
return 0;
if(s<=l && e>=r)
return segtree[node];
int m=(l+r)/2;
int p1=query((2*node),l,m,s,e);
int p2=query((2*node+1),m+1,r,s,e);
}
public static int querypath(int u,int v)
{
int lca=lca(u,v);
return Math.
max(queryup
(u,lca
), queryup
(v,lca
)); }
public static int queryup(int u,int v)
{
if(u==v)
return 0;
int lchain;int rchain=chainind[v];
int ans=-1;
while(true)
{
lchain=chainind[u];
if(lchain==rchain)
{
if(u==v)
break;
int cur=query(1,1,pos,arrpos[v]+1,arrpos[u]);
break;
}
int cur=query(1,1,pos,chainhead[lchain],arrpos[u]);
u=chainhead[lchain];
u=p[u][0];
}
return ans;
}
public static void update(int ind,int val)
{
int no=endnode[ind];
update(1,1,pos,arrpos[no],val);
}
}
private static class Pair implements Comparable<Pair>{
int v,i;Pair j;
public Pair(int a,int b){
v=a;
i=b;
}
public Pair(int a,Pair b)
{
v=a;
j=b;
}
@Override
public int compareTo(Pair arg0) {
{
return this.v-arg0.v;
}
}
}
private static long pow(long a, long b, long c) {
if (b == 0)
return 1;
long p = pow(a, b / 2, c);
p = (p * p) % c;
return (b % 2 == 0) ? p : (a * p) % c;
}
private static long gcd(long n, long l) {
if (l == 0)
return n;
return gcd(l, n % l);
}
private static long max(long a, long b) {
if (a > b)
return a;
return b;
}
private static long min(long a, long b) {
if (a < b)
return a;
return b;
}
@Override
public void run() {
/*try {
InputReader(new FileInputStream("C:\\Users\\hardik\\Desktop\\C-small-1-attempt1.in"));
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}*/
/*try {
pw=new PrintWriter(new FileOutputStream("C:\\Users\\hardik\\Desktop\\out.txt"));
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}*/
soln();
pw.close();
}
},"1",1<<26).start();
}
stream = stream1;
}
private static boolean isWhitespace(int c) {
return c == ' ' || c == '\n' || c == '\r' || c == '\t' || c == -1;
}
private static boolean isEndOfLine(int c) {
return c == '\n' || c == '\r' || c == -1;
}
private static int read() {
if (numChars == -1)
throw new InputMismatchException();
if (curChar >= numChars) {
curChar = 0;
try {
numChars = stream.read(buf);
throw new InputMismatchException();
}
if (numChars <= 0)
return -1;
}
return buf[curChar++];
}
private static int ni() {
int c = read();
while (isSpaceChar(c))
c = read();
int sgn = 1;
if (c == '-') {
sgn = -1;
c = read();
}
int res = 0;
do {
if (c < '0' || c > '9')
throw new InputMismatchException();
res *= 10;
res += c - '0';
c = read();
} while (!isSpaceChar(c));
return res * sgn;
}
private static long nl() {
int c = read();
while (isSpaceChar(c))
c = read();
int sgn = 1;
if (c == '-') {
sgn = -1;
c = read();
}
long res = 0;
do {
if (c < '0' || c > '9')
throw new InputMismatchException();
res *= 10;
res += c - '0';
c = read();
} while (!isSpaceChar(c));
return res * sgn;
}
private static double nd()
{
double ret = 0, div = 1;
int c = read();
while (c <= ' ')
c = read();
boolean neg = (c == '-');
if (neg)
c = read();
do {
ret = ret * 10 + c - '0';
}
while ((c = read()) >= '0' && c <= '9');
if (c == '.')
{
while ((c = read()) >= '0' && c <= '9')
{
ret += (c - '0') / (div *= 10);
}
}
if (neg)
return -ret;
return ret;
}
private static String nextToken
() { int c = read();
while (isSpaceChar(c))
c = read();
StringBuilder res = new StringBuilder();
do {
res.appendCodePoint(c);
c = read();
} while (!isSpaceChar(c));
return res.toString();
}
int c = read();
while (isSpaceChar(c))
c = read();
StringBuilder res = new StringBuilder();
do {
res.appendCodePoint(c);
c = read();
} while (!isEndOfLine(c));
return res.toString();
}
private static int[] nia(int n) {
int[] arr = new int[n];
for (int i = 0; i < n; i++) {
arr[i] = ni();
}
return arr;
}
private static long[] nla(int n) {
long[] arr = new long[n];
for (int i = 0; i < n; i++) {
arr[i] = nl();
}
return arr;
}
private static void pa(int[] arr) {
for (int i = 0; i < arr.length; i++) {
pw.print(arr[i] + " ");
}
pw.println();
return;
}
private static void pa(long[] arr) {
for (int i = 0; i < arr.length; i++) {
pw.print(arr[i] + " ");
}
return;
}
private static boolean isSpaceChar(int c) {
if (filter != null)
return filter.isSpaceChar(c);
return isWhitespace(c);
}
private static char nc() {
int c = read();
while (isSpaceChar(c))
c = read();
char c1=(char)c;
while(!isSpaceChar(c))
c=read();
return c1;
}
private interface SpaceCharFilter {
public boolean isSpaceChar(int ch);
}
}
import java.io.*;
import java.math.*;
import java.util.*;
/* 
																yash jobanputra
																	DA-IICT
*/
class mstkp {
	private static InputStream stream;
	private static byte[] buf = new byte[1024];
	private static int curChar;
	private static int numChars;
	private static SpaceCharFilter filter;
	private static PrintWriter pw;
	private static long mod = 1000000000 + 7;
	private static long mod1 = 1000000000 + 9;
	private static int MAX=1000001;
	private static int block;
	private static int count;
	private static boolean[] vis;
	private static Stack<Integer> st;
	private static int times=0;
	public static int cc;
	public static int pos;
	private static void soln(){
			int t=ni();
			for(int c=0;c<t;c++)
			{
				int n=ni();
				ArrayList<Pair>[] tree=new ArrayList[n+1];
				int[][] ecost=new int[n+1][n+1];
				for(int i=0;i<=n;i++)
				{
					tree[i]=new ArrayList<>();
				}
				for(int i=1;i<n;i++)
				{
					int a=ni();int b=ni();int cost=ni();
					tree[a].add(new Pair(b,i));
					tree[b].add(new Pair(a,i));
					ecost[a][b]=cost;
					ecost[b][a]=cost;
				}
				hld.initial(n);
				hld.dfs(1, 1, tree);
				hld.ilca(n);
				hld.Hld(1, 0, -1, tree, ecost);
				hld.build(1, 1, pos);
				while(true)
				{
					String[] s=nli().split(" ");
					if(s[0].contentEquals("DONE"))
						break;
					else if(s[0].contentEquals("QUERY"))
						pw.println(hld.querypath(Integer.parseInt(s[1]), Integer.parseInt(s[2])));
					else
						hld.update(Integer.parseInt(s[1]), Integer.parseInt(s[2]));
				}
			}
		}
	public static class hld
	{
		static int[][] p;static int[] dp;static int[] subsize;static int[] endnode;static int chainno;static int[] chainhead,chainind,arrpos,costarr,segtree;
		public static void initial(int n)
		{
			p=new int[n+1][22];
			dp=new int[n+1];
			subsize=new int[n+1];
			endnode=new int[n];
			chainhead=new int[n+1];
			chainind=new int[n+1];
			arrpos=new int[n+1];
			costarr=new int[n];
			segtree=new int[n*4];
			chainno=1;
			pos=-1;
			Arrays.fill(chainhead, -1);
		}
		public static void ilca(int n)
		{
			for(int i=1;i<=n;i++)
			{
				for(int j=1;j<22;j++)
					p[i][j]=-1;
			}
			for(int j=1;1<<j<=n;j++)
			{
				for(int i=1;i<=n;i++)
				{
					if(p[i][j-1]!=-1)
						p[i][j]=p[p[i][j-1]][j-1];
				}
			}
		}
		public static void dfs(int node,int par,ArrayList<Pair>[] tree)
		{
			if(par==0)	dp[node]=0;
			subsize[node]=1;
			p[node][0]=par;
			for(int i=0;i<tree[node].size();i++)
			{
				int next=tree[node].get(i).v;
				int ind=tree[node].get(i).i;
				if(next!=par)
				{
					endnode[ind]=next;
					dfs(next,node,tree);
					subsize[node]+=subsize[next];
				}
			}
		}
		public static int lca(int u,int v)
		{
			if(dp[u]<dp[v])
			{
				int temp=u;
				u=v;
				v=temp;
			}
			int log;
			for (log = 1; 1 << log <= dp[u]; log++);
		      log--;
		    for(int i=log;i>=0;i--)
		    {
		    	if(dp[u]-(1<<i)>=dp[v])
		    		u=p[u][i];
		    }
		    if(u==v)
		    	return u;
		    for(int i=log;i>=0;i--)
		    {
		    	if(p[u][i]!=-1 && p[u][i]!=p[v][i])
		    		{u=p[u][i];v=p[v][i];}
		    }
		    return p[u][0];
		}
		public static void Hld(int node,int cost,int par,ArrayList<Pair>[] tree,int[][] ecost)
		{
			if(chainhead[chainno]==-1)	chainhead[chainno]=node;
			pos++;
			chainind[node]=chainno;
			costarr[pos]=cost;
			arrpos[node]=pos;
			int hn=-1;int hc=0;
			for(int i=0;i<tree[node].size();i++)
			{
				int next=tree[node].get(i).v;
				if((next!=par)&&(hn==-1 || subsize[next]>subsize[hn]))
				{
					hn=next;
					hc=ecost[node][next];
				}
			}
			if(hn!=-1)
				Hld(hn,hc,node,tree,ecost);
			for(int i=0;i<tree[node].size();i++)
			{
				int next=tree[node].get(i).v;
				if(next!=par && next!=hn)
				{
					chainno++;
					Hld(next,ecost[node][next],node,tree,ecost);
				}
			}
		}
		public static void build(int node,int l,int r)
		{
			if(l==r)
			{
				segtree[node]=costarr[l];
			}
			else
			{
				int m=(l+r)/2;
				build((2*node),l,m);
				build((2*node)+1,m+1,r);
				segtree[node]=Math.max(segtree[2*node],segtree[2*node+1]);
			}
		}
		public static void update(int node,int l,int r,int ind,int val)
		{
			if(l==r)
			{
				costarr[ind]=val;
				segtree[node]=val;
			}
			else
			{
				int m=(l+r)/2;
				if(l<=ind && ind<=m)
				{
					update((2*node),l,m,ind,val);
				}
				else
				{
					update((2*node+1),m+1,r,ind,val);
				}
				segtree[node]=Math.max(segtree[2*node], segtree[2*node+1]);
			}
		}
		public static int query(int node,int l,int r,int s,int e)
		{
			if(e<l || r<s)
				return 0;
			if(s<=l && e>=r)
				return segtree[node];
			int m=(l+r)/2;
			int p1=query((2*node),l,m,s,e);
			int p2=query((2*node+1),m+1,r,s,e);
			return Math.max(p1, p2);
		}
		public static int querypath(int u,int v)
		{
			int lca=lca(u,v);
			return Math.max(queryup(u,lca), queryup(v,lca));
		}
		public static int queryup(int u,int v)
		{
			if(u==v)
				return 0;
			int lchain;int rchain=chainind[v];
			int ans=-1;
			while(true)
			{
				lchain=chainind[u];
				if(lchain==rchain)
				{
					if(u==v)
						break;
					int cur=query(1,1,pos,arrpos[v]+1,arrpos[u]);
					ans=Math.max(cur, ans);
					break;
				}
				int cur=query(1,1,pos,chainhead[lchain],arrpos[u]);
				ans=Math.max(cur,ans);
				u=chainhead[lchain];
				u=p[u][0];
			}
			return ans;
		}
		public static void update(int ind,int val)
		{
			int no=endnode[ind];
			update(1,1,pos,arrpos[no],val);
		}
	}
	private static class Pair implements Comparable<Pair>{
		int v,i;Pair j;
		public Pair(int a,int b){
			v=a;
			i=b;
		}
		public Pair(int a,Pair b)
		{
			v=a;
			j=b;
		}
		@Override
		public int compareTo(Pair arg0) {
			{
				return this.v-arg0.v;
			}
		}
	}
	
	private static long pow(long a, long b, long c) {
		if (b == 0)
			return 1;
		long p = pow(a, b / 2, c);
		p = (p * p) % c;
		return (b % 2 == 0) ? p : (a * p) % c;
	}
	private static long gcd(long n, long l) {
		if (l == 0)
			return n;
		return gcd(l, n % l);
	}

	private static long max(long a, long b) {
		if (a > b)
			return a;
		return b;
	}

	private static long min(long a, long b) {
		if (a < b)
			return a;
		return b;
	}

	public static void main(String[] args) throws Exception {
		new Thread(null,new Runnable(){
			@Override
			public void run() {
				/*try {
					InputReader(new FileInputStream("C:\\Users\\hardik\\Desktop\\C-small-1-attempt1.in"));
				} catch (FileNotFoundException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}*/
				InputReader(System.in);
				pw = new PrintWriter(System.out);
				/*try {
					pw=new PrintWriter(new FileOutputStream("C:\\Users\\hardik\\Desktop\\out.txt"));
				} catch (FileNotFoundException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}*/
				soln();
				pw.close();
			}
		},"1",1<<26).start();
	}

	public static void InputReader(InputStream stream1) {
		stream = stream1;
	}

	private static boolean isWhitespace(int c) {
		return c == ' ' || c == '\n' || c == '\r' || c == '\t' || c == -1;
	}

	private static boolean isEndOfLine(int c) {
		return c == '\n' || c == '\r' || c == -1;
	}

	private static int read() {
		if (numChars == -1)
			throw new InputMismatchException();
		if (curChar >= numChars) {
			curChar = 0;
			try {
				numChars = stream.read(buf);
			} catch (IOException e) {
				throw new InputMismatchException();
			}
			if (numChars <= 0)
				return -1;
		}
		return buf[curChar++];
	}

	private static int ni() {
		int c = read();
		while (isSpaceChar(c))
			c = read();
		int sgn = 1;
		if (c == '-') {
			sgn = -1;
			c = read();
		}
		int res = 0;
		do {
			if (c < '0' || c > '9')
				throw new InputMismatchException();
			res *= 10;
			res += c - '0';
			c = read();
		} while (!isSpaceChar(c));
		return res * sgn;
	}

	private static long nl() {
		int c = read();
		while (isSpaceChar(c))
			c = read();
		int sgn = 1;
		if (c == '-') {
			sgn = -1;
			c = read();
		}
		long res = 0;
		do {
			if (c < '0' || c > '9')
				throw new InputMismatchException();
			res *= 10;
			res += c - '0';
			c = read();
		} while (!isSpaceChar(c));
		return res * sgn;
	}
	private static double nd()
    {
        double ret = 0, div = 1;
        int c = read();
        while (c <= ' ')
            c = read();
        boolean neg = (c == '-');
        if (neg)
            c = read();

        do {
            ret = ret * 10 + c - '0';
        }
        while ((c = read()) >= '0' && c <= '9');

        if (c == '.')
        {
            while ((c = read()) >= '0' && c <= '9')
            {
                ret += (c - '0') / (div *= 10);
            }
        }

        if (neg)
            return -ret;
        return ret;
    }
	private static String nextToken() {
		int c = read();
		while (isSpaceChar(c))
			c = read();
		StringBuilder res = new StringBuilder();
		do {
			res.appendCodePoint(c);
			c = read();
		} while (!isSpaceChar(c));
		return res.toString();
	}

	private static String nli() {
		int c = read();
		while (isSpaceChar(c))
			c = read();
		StringBuilder res = new StringBuilder();
		do {
			res.appendCodePoint(c);
			c = read();
		} while (!isEndOfLine(c));
		return res.toString();
	}
	
	private static int[] nia(int n) {
		int[] arr = new int[n];
		for (int i = 0; i < n; i++) {
			arr[i] = ni();
		}
		return arr;
	}

	private static long[] nla(int n) {
		long[] arr = new long[n];
		for (int i = 0; i < n; i++) {
			arr[i] = nl();
		}
		return arr;
	}

	private static void pa(int[] arr) {
		for (int i = 0; i < arr.length; i++) {
			pw.print(arr[i] + " ");
		}
		pw.println();
		return;
	}

	private static void pa(long[] arr) {
		for (int i = 0; i < arr.length; i++) {
			pw.print(arr[i] + " ");
		}
		System.out.println();
		return;
	}

	private static boolean isSpaceChar(int c) {
		if (filter != null)
			return filter.isSpaceChar(c);
		return isWhitespace(c);
	}
	private static char nc() {
		int c = read();
		while (isSpaceChar(c))
			c = read();
		char c1=(char)c;
		while(!isSpaceChar(c))
			c=read();
		return c1;
	}
	private interface SpaceCharFilter {
		public boolean isSpaceChar(int ch);
	}
}