1 package Math::GSL::QRNG::Test;
2 use base q{Test::Class};
3 use Test::More tests => 8;
4 use Math::GSL::QRNG qw/:all/;
5 use Math::GSL::Test qw/:all/;
6 use Math::GSL::Errno qw/:all/;
10 sub make_fixture : Test(setup) {
12 $self->{sobol} = gsl_qrng_alloc($gsl_qrng_sobol, 2);
15 sub teardown : Test(teardown) {
17 gsl_qrng_free($self->{sobol});
20 sub GSL_QRNG_ALLOC : Tests {
21 my $qrng = gsl_qrng_alloc($gsl_qrng_sobol, 2);
22 isa_ok( $qrng, 'Math::GSL::QRNG');
25 sub GSL_QRNG_STATE_SIZE : Tests {
27 my $state = gsl_qrng_state($self->{sobol});
28 my $size = gsl_qrng_size($self->{sobol});
29 ok( defined $state && $state >0 , 'gsl_qrng_state' );
30 ok( defined $size && $size > 0, 'gsl_qrng_size' );
33 sub GSL_QRNG_CLONE : Tests {
35 my $droid = gsl_qrng_clone($self->{sobol});
36 isa_ok($droid, 'Math::GSL::QRNG' );
39 sub GSL_QRNG_NAME : Tests {
41 my $name = gsl_qrng_name($self->{sobol});
42 ok ($name eq 'sobol', 'gsl_qrng_name' );
45 sub GSL_QRNG_GET : Tests {
47 my ($status, @values)= gsl_qrng_get($self->{sobol});
49 is ($status, $GSL_SUCCESS);
50 ok_similar( [ 0.5, 0.5 ], \@values, 'gsl_qrng_get returns multiple values' );
51 ($status, @values)= gsl_qrng_get($self->{sobol});
52 ok_similar( [ 0.75, 0.25 ], \@values, 'gsl_qrng_get returns correct values for sobol' );
54 Test::Class->runtests;