Advertisement
JeffGrigg

Untitled

Dec 17th, 2017
263
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Java 5 2.31 KB | None | 0 0
  1. import junit.framework.TestCase;
  2.  
  3. import java.math.BigInteger;
  4.  
  5. public class CheckPrimeNumberTest extends TestCase {
  6.  
  7.     public void testPrimeNumbersUpTo1000() {
  8.         // "List of Prime Numbers up to 1000"
  9.         // https://www.miniwebtool.com/list-of-prime-numbers/?to=1000
  10.         final int[] primeNumbers = {
  11.                 2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97,
  12.                 101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199,
  13.                 211, 223, 227, 229, 233, 239, 241, 251, 257, 263, 269, 271, 277, 281, 283, 293,
  14.                 307, 311, 313, 317, 331, 337, 347, 349, 353, 359, 367, 373, 379, 383, 389, 397,
  15.                 401, 409, 419, 421, 431, 433, 439, 443, 449, 457, 461, 463, 467, 479, 487, 491, 499,
  16.                 503, 509, 521, 523, 541, 547, 557, 563, 569, 571, 577, 587, 593, 599,
  17.                 601, 607, 613, 617, 619, 631, 641, 643, 647, 653, 659, 661, 673, 677, 683, 691,
  18.                 701, 709, 719, 727, 733, 739, 743, 751, 757, 761, 769, 773, 787, 797,
  19.                 809, 811, 821, 823, 827, 829, 839, 853, 857, 859, 863, 877, 881, 883, 887,
  20.                 907, 911, 919, 929, 937, 941, 947, 953, 967, 971, 977, 983, 991, 997,
  21.                 9999
  22.         };
  23.         StringBuilder errorMessage = new StringBuilder();
  24.  
  25.         int arrIdx = 0;
  26.         for (int testNumber = 0; testNumber <= 1000; ++testNumber) {
  27.             final boolean isPrime = (testNumber == primeNumbers[arrIdx]);
  28.  
  29.             final BigInteger inputValueToTest = new BigInteger(String.valueOf(testNumber));
  30.  
  31.             final boolean computedPrimeFlag = CheckPrimeNumber.isPrime(inputValueToTest);
  32.  
  33.             if (computedPrimeFlag != isPrime) {
  34.                 errorMessage.append("  isPrime(").append(inputValueToTest).append(")")
  35.                         .append(" returned ").append(computedPrimeFlag).append(",")
  36.                         .append(" but the correct value is ").append(isPrime)
  37.                         .append(System.lineSeparator());
  38.             }
  39.  
  40.             if (isPrime) {
  41.                 ++arrIdx;
  42.             }
  43.         }
  44.  
  45.         if (errorMessage.length() > 0) {
  46.             fail("ERROR:" + System.lineSeparator() + errorMessage.toString());
  47.         }
  48.     }
  49.  
  50. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement