Amazon-DynamoDB

 view release on metacpan or  search on metacpan

t/07-query.t  view on Meta::CPAN

#!perl
use strict;
use warnings;
use lib ('lib', './t');
use Test::Most;
use Test::Differences;
use List::MoreUtils;
use Data::Dumper;
use TestSettings;

unless ( $ENV{'AMAZON_DYNAMODB_EXPENSIVE_TESTS'} ) {
    plan skip_all => 'Testing this module for real costs money.';
} else {
    plan tests => 10;
}

bail_on_fail;

my $ddb = TestSettings::get_ddb();
my $table_name = TestSettings::random_table_name();


my $create = $ddb->create_table(TableName => $table_name,
                                ReadCapacityUnits => 2,
                                WriteCapacityUnits => 2,
                                AttributeDefinitions => {
                                    user_id => 'N',
                                },
                                KeySchema => ['user_id'],
                            );

ok($create->is_done, "Create request was completed");

my $wait = $ddb->wait_for_table_status(TableName => $table_name);

ok($wait->is_done, "Created table is ready");



my @put_items = map {
    my $r = {
        user_id => int($_),
        name => "Test record: " . $_,
    } ;
} (1..10);
    
ok($ddb->batch_write_item(
    RequestItems => {
        $table_name => [
            map {
                {
                    PutRequest => { Item => $_ }
                }
            } @put_items
        ]
    })->is_done, "Batch write item successfully completed");


{
    my $query = $ddb->query(sub {},
                            TableName => $table_name,
                            Select => 'COUNT',
                            KeyConditions => {
                                user_id => {



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