From 1370ae77f47a818d49e0c7d6bb8938ab2eef6fe9 Mon Sep 17 00:00:00 2001 From: shawnlaffan Date: Fri, 8 Nov 2024 09:09:53 +1100 Subject: [PATCH] Rand spatial curveball: more tests And try to use any defined spatial condition. Let the parser handle the rest. --- lib/Biodiverse/Randomise/CurveBall.pm | 5 ++-- t/28-Randomisation.t | 43 ++++++++++++++++++++++++++- 2 files changed, 45 insertions(+), 3 deletions(-) diff --git a/lib/Biodiverse/Randomise/CurveBall.pm b/lib/Biodiverse/Randomise/CurveBall.pm index 0e95e4f1a..620742f10 100644 --- a/lib/Biodiverse/Randomise/CurveBall.pm +++ b/lib/Biodiverse/Randomise/CurveBall.pm @@ -148,7 +148,8 @@ END_PROGRESS_TEXT $progress_bar->reset; my (%sp_swap_list, @gps_with_nbrs); - if (my $sp_conditions = $args{spatial_condition_for_swap_pairs}) { + my $sp_conditions = $args{spatial_condition_for_swap_pairs}; + if (defined $sp_conditions) { my $sp_swapper = $self->get_spatial_output_for_label_allocation ( %args, spatial_conditions_for_label_allocation => $sp_conditions, @@ -178,7 +179,7 @@ END_PROGRESS_TEXT @gps_with_nbrs = sort keys %sp_swap_list; my $n_gps_w_nbrs = @gps_with_nbrs; say "[Randomise] $n_gps_w_nbrs of $n_groups groups have swappable neighbours"; - croak "No groups have neighbours, cannot swap labels with neighbours" + croak "[Randomise] Curveball spatial: No groups have neighbours, cannot swap labels with neighbours" if !@gps_with_nbrs; } } diff --git a/t/28-Randomisation.t b/t/28-Randomisation.t index a3ce28e9c..3f295bda8 100644 --- a/t/28-Randomisation.t +++ b/t/28-Randomisation.t @@ -1,4 +1,4 @@ -use 5.010; +use 5.036; use strict; use warnings; @@ -146,6 +146,7 @@ sub test_rand_curveball_sp_cond { }; my $i; foreach my $bd (@$rand_bd_array) { + # $bd->save; # for debug $i++; my %collated_labels; foreach my $gp (qw /3250000:3050000 3150000:2950000 3250000:2950000 3250000:2850000/) { @@ -156,6 +157,45 @@ sub test_rand_curveball_sp_cond { } is \%collated_labels, $expected, "Curveball spatial: labels and counts for isolated subregion, rand bd $i"; } + + # use one of the random basedatas to test some oddball spatial conditions that should throw errors + my $bd = $rand_bd_array->[0]; + my %die_combos = ( + Rando1 => 'sp_self_only()', + Rando2 => '0 ', + Rando3 => '0', + Rando4 => '0 # zero with comment', + ); + foreach my $name (sort keys %die_combos) { + my $condition = $die_combos{$name}; + my $rand = $bd->add_randomisation_output(name => $name); + ok dies { + $rand->run_analysis( + function => 'rand_curveball', + iterations => 1, + spatial_condition_for_swap_pairs => $condition, + ) + }, qq{rand_curveball with condition "$condition" dies}; + } + + # use another of the random basedatas to test some oddball spatial conditions that should be ignored + $bd = $rand_bd_array->[1]; + my %ignore_combos = ( + Rando1i => ' ', + Rando2i => '# just a comment', + ); + foreach my $name (sort keys %ignore_combos) { + my $condition = $ignore_combos{$name}; + my $rand = $bd->add_randomisation_output(name => $name); + ok lives { + $rand->run_analysis( + function => 'rand_curveball', + iterations => 1, + spatial_condition_for_swap_pairs => $condition, + ) + }, "rand_curveball with condition '$condition' lives"; + } + } sub test_rand_structured_richness_same { @@ -202,6 +242,7 @@ sub test_rand_structured_richness_same { iterations => 3, seed => $prng_seed, return_rand_bd_array => 1, + retain_outputs => 1, %args, );