use Modern::Perl;
-use Test::More tests => 12;
+use Test::More tests => 15;
use C4::Context;
}
can_ok(
'C4::Reports::Guided',
- qw(save_report
- delete_report)
+ qw(save_report delete_report execute_query)
);
#Start transaction
is( scalar( @{ get_saved_reports() } ),
$count, "Report2 and report3 have been deleted" );
+my $sth = execute_query('SELECT COUNT(*) FROM systempreferences', 0, 10);
+my $results = $sth->fetchall_arrayref;
+is(scalar(@$results), 1, 'running a query returned a result');
+
+my $version = C4::Context->preference('Version');
+$sth = execute_query(
+ 'SELECT value FROM systempreferences WHERE variable = ?',
+ 0,
+ 10,
+ [ 'Version' ],
+);
+$results = $sth->fetchall_arrayref;
+is_deeply(
+ $results,
+ [ [ $version ] ],
+ 'running a query with a parameter returned the expected result'
+);
+
+# for next test, we want to let execute_query capture any SQL errors
+$dbh->{RaiseError} = 0;
+my $errors;
+($sth, $errors) = execute_query(
+ 'SELECT surname FRM borrowers', # error in the query is intentional
+ 0,
+ 10,
+);
+ok(
+ defined($errors) && exists($errors->{queryerr}),
+ 'attempting to run a report with an SQL syntax error returns error message (Bug 12214)'
+);
+
#End transaction
$dbh->rollback;