para loop encontrando os números primos

Eu estou tentando executar esse código para imprimir a soma de todos os números primos menos de 2 milhões. Esse loop nunca termina. Alguém pode me dizer o que está errado com o código? Parece funcionar com números menores embora.

public static void main(String[] args) {

        long result = 1;

        for(int i=0; i<2000000; i++) {
            if(isPrime(i)) {
                result+= i;
            }
        }
        System.out.println(result);

    }
private static boolean isPrime(long n) {
    boolean result = false;

    for(long i=2; i<(long)Math.sqrt(n); i++) {
        if(n%i == 0) {
            result = false;
            break;
        }
        else result = true;
    }
    return result;
}

questionAnswers(5)

yourAnswerToTheQuestion