int main(int argc, char **argv) { /* find iteration count */ if (argc > 1) { count = strtol(argv[1], NULL, 0); } /* find random seed */ uint64_t seed; if (argc > 2) { seed = strtoull(argv[2], NULL, 0); } else { FILE *frand = fopen("/dev/urandom", "r"); if (!frand || !fread(&seed, sizeof(seed), 1, frand)) { seed = time(NULL) * 1337; } fclose(frand); } secp256k1_rand_seed(seed); printf("test count = %i\n", count); printf("random seed = %llu\n", (unsigned long long)seed); /* initialize */ secp256k1_start(SECP256K1_START_SIGN | SECP256K1_START_VERIFY); /* initializing a second time shouldn't cause any harm or memory leaks. */ secp256k1_start(SECP256K1_START_SIGN | SECP256K1_START_VERIFY); /* Likewise, re-running the internal init functions should be harmless. */ secp256k1_fe_start(); secp256k1_ge_start(); secp256k1_scalar_start(); secp256k1_ecdsa_start(); #ifndef USE_NUM_NONE /* num tests */ run_num_smalltests(); #endif /* scalar tests */ run_scalar_tests(); /* field tests */ run_field_inv(); run_field_inv_var(); run_field_inv_all(); run_field_inv_all_var(); run_sqr(); run_sqrt(); /* group tests */ run_ge(); /* ecmult tests */ run_wnaf(); run_point_times_order(); run_ecmult_chain(); /* ecdsa tests */ run_ecdsa_sign_verify(); run_ecdsa_end_to_end(); run_ecdsa_edge_cases(); #ifdef ENABLE_OPENSSL_TESTS run_ecdsa_openssl(); #endif printf("random run = %llu\n", (unsigned long long)secp256k1_rand32() + ((unsigned long long)secp256k1_rand32() << 32)); /* shutdown */ secp256k1_stop(); /* shutting down twice shouldn't cause any double frees. */ secp256k1_stop(); /* Same for the internal shutdown functions. */ secp256k1_fe_stop(); secp256k1_ge_stop(); secp256k1_scalar_stop(); secp256k1_ecdsa_stop(); return 0; }
int main(int argc, char **argv) { /* find iteration count */ if (argc > 1) { count = strtol(argv[1], NULL, 0); } /* find random seed */ uint64_t seed; if (argc > 2) { seed = strtoull(argv[2], NULL, 0); } else { FILE *frand = fopen("/dev/urandom", "r"); if (!frand || !fread(&seed, sizeof(seed), 1, frand)) { seed = time(NULL) * 1337; } fclose(frand); } secp256k1_rand_seed(seed); printf("test count = %i\n", count); printf("random seed = %llu\n", (unsigned long long)seed); /* initialize */ secp256k1_start(SECP256K1_START_SIGN | SECP256K1_START_VERIFY); /* num tests */ run_num_smalltests(); /* scalar tests */ run_scalar_tests(); /* field tests */ run_field_inv(); run_field_inv_var(); run_field_inv_all(); run_field_inv_all_var(); run_sqr(); run_sqrt(); /* group tests */ run_ge(); /* ecmult tests */ run_wnaf(); run_point_times_order(); run_ecmult_chain(); /* ecdsa tests */ run_ecdsa_sign_verify(); run_ecdsa_end_to_end(); run_ecdsa_infinity(); #ifdef ENABLE_OPENSSL_TESTS run_ecdsa_openssl(); #endif printf("random run = %llu\n", (unsigned long long)secp256k1_rand32() + ((unsigned long long)secp256k1_rand32() << 32)); /* shutdown */ secp256k1_stop(); return 0; }