Blame nss/lib/freebl/mpi/tests/mptest-8.c

Packit 40b132
/*
Packit 40b132
 *  Simple test driver for MPI library
Packit 40b132
 *
Packit 40b132
 *  Test 8: Probabilistic primality tester
Packit 40b132
 *
Packit 40b132
 * This Source Code Form is subject to the terms of the Mozilla Public
Packit 40b132
 * License, v. 2.0. If a copy of the MPL was not distributed with this
Packit 40b132
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
Packit 40b132
Packit 40b132
#include <stdio.h>
Packit 40b132
#include <stdlib.h>
Packit 40b132
#include <string.h>
Packit 40b132
#include <ctype.h>
Packit 40b132
#include <limits.h>
Packit 40b132
#include <time.h>
Packit 40b132
Packit 40b132
#define MP_IOFUNC 1
Packit 40b132
#include "mpi.h"
Packit 40b132
Packit 40b132
#include "mpprime.h"
Packit 40b132
Packit 40b132
int main(int argc, char *argv[])
Packit 40b132
{
Packit 40b132
  int       ix;
Packit 40b132
  mp_digit  num;
Packit 40b132
  mp_int    a;
Packit 40b132
Packit 40b132
  srand(time(NULL));
Packit 40b132
Packit 40b132
  if(argc < 2) {
Packit 40b132
    fprintf(stderr, "Usage: %s \n", argv[0]);
Packit 40b132
    return 1;
Packit 40b132
  }
Packit 40b132
Packit 40b132
  printf("Test 8: Probabilistic primality testing\n\n");
Packit 40b132
Packit 40b132
  mp_init(&a);
Packit 40b132
Packit 40b132
  mp_read_radix(&a, argv[1], 10);
Packit 40b132
Packit 40b132
  printf("a = "); mp_print(&a, stdout); fputc('\n', stdout);
Packit 40b132
Packit 40b132
  printf("\nChecking for divisibility by small primes ... \n");
Packit 40b132
  num = 170;
Packit 40b132
  if(mpp_divis_primes(&a, &num) == MP_YES) {
Packit 40b132
    printf("it is not prime\n");
Packit 40b132
    goto CLEANUP;
Packit 40b132
  }
Packit 40b132
  printf("Passed that test (not divisible by any small primes).\n");
Packit 40b132
Packit 40b132
  for(ix = 0; ix < 10; ix++) {
Packit 40b132
    printf("\nPerforming Rabin-Miller test, iteration %d\n", ix + 1);
Packit 40b132
Packit 40b132
    if(mpp_pprime(&a, 5) == MP_NO) {
Packit 40b132
      printf("it is not prime\n");
Packit 40b132
      goto CLEANUP;
Packit 40b132
    }
Packit 40b132
  }
Packit 40b132
  printf("All tests passed; a is probably prime\n");
Packit 40b132
Packit 40b132
CLEANUP:
Packit 40b132
  mp_clear(&a);
Packit 40b132
Packit 40b132
  return 0;
Packit 40b132
}