Google-BigQuery

 view release on metacpan or  search on metacpan

t/13_select_errors.t  view on Meta::CPAN

BEGIN {
  unless (defined $ENV{CLIENT_EMAIL} && defined $ENV{PRIVATE_KEY_FILE} && $ENV{PROJECT_ID}) {
    require Test::More;
    Test::More::plan(skip_all => 'This test needs $ENV{CLIENT_EMAIL}, $ENV{PRIVATE_KEY_FILE} and $ENV{PROJECT_ID}.');
  }
}

use strict;
use Test::More 0.98;
use Test::Exception;
use JSON qw(decode_json encode_json);
use Data::Dumper;
use FindBin '$Bin';

use Google::BigQuery;

my $client_email = $ENV{CLIENT_EMAIL};
my $private_key_file = $ENV{PRIVATE_KEY_FILE};
my $project_id = $ENV{PROJECT_ID};
my ${dataset_id} = 'sample_dataset_' . time;
my $table_id = 'sample_table_' . time;
my $schema = [
  { name => 'id', type => 'INTEGER', mode => 'REQUIRED' },
  { name => 'name', type => 'STRING', mode => 'REQUIRED' },
];
my $ret;

my $bq = Google::BigQuery::create(
  client_email=>$client_email,
  private_key_file=>$private_key_file,
  project_id=>$project_id,
  dataset_id=>$dataset_id,
);

$bq->create_dataset;
$bq->create_table(table_id=>$table_id,schema=>$schema);
my $values = [
  { id => 1, name => 'foo' },
  { id => 2, name => 'baz' },
  { id => 3, name => 'bar' },
];
$bq->insert(table_id=>$table_id,values=>$values);

# not found field
if (1) {
  my $query = "SELECT xxx FROM $table_id";
  is($bq->selectall_arrayref(query => $query), 0, 'select: not found field');
}

# not found table
if (1) {
  my $query = "SELECT xxx FROM ${table_id}x";
  is($bq->selectall_arrayref(query => $query), 0, 'select: not found table');
}

# sql syntax error
if (1) {
  my $query = "SELECT id, COUNT(*) FROM $table_id";
  is($bq->selectrow_array(query => $query), 0, 'select: sql syntax error');
}

done_testing;



( run in 0.976 second using v1.01-cache-2.11-cpan-39bf76dae61 )