import java.io.* ;
import java.util.* ;
/**
* Created by Shreyans on 4/21/2015 at 1:37 AM using IntelliJ IDEA (Fast IO Template)
*/
//ADD PUBLIC FOR CF,TC
class EZDIJKST
{
{
InputReader in
= new InputReader
( System .
in ) ; OutputWriter out
= new OutputWriter
( System .
out ) ; int t= in.readInt ( ) ;
for ( int i1= 0 ; i1< t; i1++ )
{
List
< ArrayList
< AbstractMap .
SimpleEntry < Integer ,Integer
>>> gr
= new ArrayList
< ArrayList
< AbstractMap .
SimpleEntry < Integer , Integer
>>> ( ) ; //AbstractMap.SimpleEntry<Integer,Integer> is similar to pair<int a,int b> in C++ int v= in.readInt ( ) ;
int e= in.readInt ( ) ;
Set< Integer> vertices= new HashSet< Integer> ( ) ;
for ( int i= 0 ; i<= v; i++ )
{
vertices.add ( i) ;
}
vertices.remove ( 0 ) ; //Not intended hence removed
for ( int i= 0 ; i< e; i++ )
{
int a = in.readInt ( ) ;
int b = in.readInt ( ) ;
int c = in.readInt ( ) ;
}
int s= in.readInt ( ) ;
int des= in.readInt ( ) ;
int [ ] d= new int [ v+ 1 ] ;
d[ s] = 0 ;
vertices.remove ( s) ;
{
ts.add ( pair) ;
d[ pair.getKey ( ) ] = pair.getValue ( ) ;
}
while ( ! vertices.isEmpty ( ) &&! ts.isEmpty ( ) )
{
int V= curr.getKey ( ) ;
int W= curr.getValue ( ) ;
{
int v1= pair.getKey ( ) ;
int w1= pair.getValue ( ) ;
if ( d[ v1] > W+ w1)
{
d[ v1] = W+ w1;
}
ts.add ( pair) ;
}
vertices.remove ( V) ;
}
{
out.printLine ( "NO" ) ;
}
else
{
out.printLine ( d[ des] ) ;
}
}
{
out.close ( ) ;
}
}
static public class WeightComparator implements
{
@Override
{
return Integer .
compare ( one.
getValue ( ) , two.
getValue ( ) ) ; }
}
//FAST IO
private static class InputReader
{
private byte [ ] buf = new byte [ 1024 ] ;
private int curChar;
private int numChars;
private SpaceCharFilter filter;
{
this .stream = stream;
}
public 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++ ] ;
}
public int readInt( )
{
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;
}
{
int c = read( ) ;
while ( isSpaceChar( c) )
c = read( ) ;
StringBuilder res = new StringBuilder( ) ;
do
{
res.appendCodePoint ( c) ;
c = read( ) ;
} while ( ! isSpaceChar( c) ) ;
return res.toString ( ) ;
}
public double readDouble( )
{
int c = read( ) ;
while ( isSpaceChar( c) )
c = read( ) ;
int sgn = 1 ;
if ( c == '-' )
{
sgn = - 1 ;
c = read( ) ;
}
double res = 0 ;
while ( ! isSpaceChar( c) && c != '.' )
{
if ( c == 'e' || c == 'E' )
return res
* Math .
pow ( 10 , readInt
( ) ) ; if ( c < '0' || c > '9' )
throw new InputMismatchException( ) ;
res *= 10 ;
res += c - '0' ;
c = read( ) ;
}
if ( c == '.' )
{
c = read( ) ;
double m = 1 ;
while ( ! isSpaceChar( c) )
{
if ( c == 'e' || c == 'E' )
return res
* Math .
pow ( 10 , readInt
( ) ) ; if ( c < '0' || c > '9' )
throw new InputMismatchException( ) ;
m /= 10 ;
res += ( c - '0' ) * m;
c = read( ) ;
}
}
return res * sgn;
}
public long readLong( )
{
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;
}
public boolean isSpaceChar( int c)
{
if ( filter != null )
return filter.isSpaceChar ( c) ;
return c == ' ' || c == '\n ' || c == '\r ' || c == '\t ' || c == - 1 ;
}
{
return readString( ) ;
}
public interface SpaceCharFilter
{
public boolean isSpaceChar( int ch) ;
}
}
private static class OutputWriter
{
{
}
public OutputWriter
( Writer writer
) {
}
public void print
( Object ...
objects ) {
for ( int i = 0 ; i < objects.length ; i++ )
{
if ( i != 0 )
writer.print ( ' ' ) ;
writer.print ( objects[ i] ) ;
}
}
public void printLine
( Object ...
objects ) {
print( objects) ;
writer.println ( ) ;
}
public void close( )
{
writer.close ( ) ;
}
public void flush( )
{
writer.flush ( ) ;
}
}
}
import java.io.*;
import java.util.*;

/**
 * Created by Shreyans on 4/21/2015 at 1:37 AM using IntelliJ IDEA (Fast IO Template)
 */

//ADD PUBLIC FOR CF,TC
class EZDIJKST
{
    public static void main(String[] args) throws Exception
    {
        InputReader in = new InputReader(System.in);
        OutputWriter out = new OutputWriter(System.out);
        int t=in.readInt();
        for(int i1=0;i1<t;i1++)
        {
            List<ArrayList<AbstractMap.SimpleEntry<Integer,Integer>>> gr=new ArrayList<ArrayList<AbstractMap.SimpleEntry<Integer, Integer>>>();//AbstractMap.SimpleEntry<Integer,Integer> is similar to pair<int a,int b> in C++
            int v=in.readInt();
            int e=in.readInt();
            Set<Integer> vertices=new HashSet<Integer>();
            for(int i=0;i<=v;i++)
            {
                vertices.add(i);
                gr.add(new ArrayList<AbstractMap.SimpleEntry<Integer, Integer>>());
            }
            vertices.remove(0);//Not intended hence removed
            for(int i=0;i<e;i++)
            {
                int a = in.readInt();
                int b = in.readInt();
                int c = in.readInt();
                gr.get(a).add(new AbstractMap.SimpleEntry<Integer, Integer>(b, c));
            }
            int s=in.readInt();
            int des=in.readInt();
            Comparator<AbstractMap.SimpleEntry<Integer, Integer>> comparator=new WeightComparator();
            TreeSet<AbstractMap.SimpleEntry<Integer, Integer>>ts=new TreeSet<AbstractMap.SimpleEntry<Integer, Integer>>(comparator);
            int[]d=new int[v+1];
            Arrays.fill(d,Integer.MAX_VALUE);
            d[s]=0;
            vertices.remove(s);
            for(AbstractMap.SimpleEntry<Integer, Integer> pair:gr.get(s))
            {
                ts.add(pair);
                d[pair.getKey()]=pair.getValue();
            }
            while(!vertices.isEmpty()&&!ts.isEmpty())
            {
                AbstractMap.SimpleEntry<Integer, Integer> curr=ts.pollFirst();
                int V=curr.getKey();
                int W=curr.getValue();
                for(AbstractMap.SimpleEntry<Integer, Integer> pair:gr.get(V))
                {
                    int v1=pair.getKey();
                    int w1=pair.getValue();
                    if(d[v1]>W+w1)
                    {
                        d[v1]=W+w1;
                    }
                    ts.add(pair);
                }
                vertices.remove(V);
            }
            if(d[des]==Integer.MAX_VALUE)
            {
                out.printLine("NO");
            }
            else
            {
                out.printLine(d[des]);
            }
        }
        Map.Entry<Integer, Integer> pair=new AbstractMap.SimpleEntry<Integer,Integer>(1,1);
        {
            out.close();
        }
    }
    static public class WeightComparator implements
            Comparator<AbstractMap.SimpleEntry<Integer, Integer>>
    {
        @Override
        public int compare(AbstractMap.SimpleEntry<Integer, Integer> one,
                           AbstractMap.SimpleEntry<Integer, Integer> two)
        {
            return Integer.compare(one.getValue(), two.getValue());
        }
    }

    //FAST IO
    private static class InputReader
    {
        private InputStream stream;
        private byte[] buf = new byte[1024];
        private int curChar;
        private int numChars;
        private SpaceCharFilter filter;

        public InputReader(InputStream stream)
        {
            this.stream = stream;
        }

        public 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++];
        }

        public int readInt()
        {
            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;
        }

        public String readString()
        {
            int c = read();
            while (isSpaceChar(c))
                c = read();
            StringBuilder res = new StringBuilder();
            do
            {
                res.appendCodePoint(c);
                c = read();
            } while (!isSpaceChar(c));
            return res.toString();
        }

        public double readDouble()
        {
            int c = read();
            while (isSpaceChar(c))
                c = read();
            int sgn = 1;
            if (c == '-')
            {
                sgn = -1;
                c = read();
            }
            double res = 0;
            while (!isSpaceChar(c) && c != '.')
            {
                if (c == 'e' || c == 'E')
                    return res * Math.pow(10, readInt());
                if (c < '0' || c > '9')
                    throw new InputMismatchException();
                res *= 10;
                res += c - '0';
                c = read();
            }
            if (c == '.')
            {
                c = read();
                double m = 1;
                while (!isSpaceChar(c))
                {
                    if (c == 'e' || c == 'E')
                        return res * Math.pow(10, readInt());
                    if (c < '0' || c > '9')
                        throw new InputMismatchException();
                    m /= 10;
                    res += (c - '0') * m;
                    c = read();
                }
            }
            return res * sgn;
        }

        public long readLong()
        {
            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;
        }

        public boolean isSpaceChar(int c)
        {
            if (filter != null)
                return filter.isSpaceChar(c);
            return c == ' ' || c == '\n' || c == '\r' || c == '\t' || c == -1;
        }

        public String next()
        {
            return readString();
        }

        public interface SpaceCharFilter
        {
            public boolean isSpaceChar(int ch);
        }
    }

    private static class OutputWriter
    {
        private final PrintWriter writer;

        public OutputWriter(OutputStream outputStream)
        {
            writer = new PrintWriter(new BufferedWriter(new OutputStreamWriter(outputStream)));
        }

        public OutputWriter(Writer writer)
        {
            this.writer = new PrintWriter(writer);
        }

        public void print(Object... objects)
        {
            for (int i = 0; i < objects.length; i++)
            {
                if (i != 0)
                    writer.print(' ');
                writer.print(objects[i]);
            }
        }

        public void printLine(Object... objects)
        {
            print(objects);
            writer.println();
        }

        public void close()
        {
            writer.close();
        }

        public void flush()
        {
            writer.flush();
        }
    }
}