Amazon-DynamoDB-Simple

 view release on metacpan or  search on metacpan

xt/amazon/dynamodb/sync.t  view on Meta::CPAN

use Test::Most;

use Amazon::DynamoDB::Simple;

my $table;
my $node   = 'boopNode';  # unique name
my $flavor = 'f';
my $cfg    = {
    node          => $node,
    flavor        => $flavor,
    region        => 'r',
    zone          => 'z',
    environment   => 'e',
    hashthing           => [{
        a           => 'firstthing',
        b           => 200,
        c           => 2000,
    }],
    domain        => 'd',
    instance_type => 'i',
    listthing     => [qw/a b c/],
};

subtest 'setup' => sub {
    $table = Amazon::DynamoDB::Simple->new(
        table       => 'server_definitions',
        primary_key => 'node',
    );

    # permanently delete item from all dynamodbs
    $table->permanent_delete($node);

    pass "done";
};

subtest 'sync: update old records' => sub {
    my %item = (
        node       => $node,
        flavor     => $cfg->{flavor},
        region     => $cfg->{region},
        zone       => $cfg->{zone},
    );

    # save to all dynamodbs
    $table->put(%item);
    sleep 1;

    # update one dynamodb
    $table->dynamodbs->[0]->put_item(
        TableName => 'server_definitions',
        Item      => {
            %item, 
            zone         => 'z',
            deleted      => 0,
            last_updated => DateTime->now() . "",
        },
    );

    # sync
    $table->sync_regions;

    # check that sync worked
    my $saved_items = {};
    for my $i (0, 1) {
        $saved_items->{$i} = $table->dynamodbs->[$i]->get_item(
            sub { shift },
            TableName => 'server_definitions',
            Key       => { node => $node },
        )->get();

        cmp_deeply $saved_items->{$i}, {
            %item,
            zone         => 'z',
            deleted      => 0,
            last_updated => re(qr/^\d{4}-\d{2}\-\d{2}T\d{2}:\d{2}:\d{2}/),
        }, "saved server definition to dynamodb $i";
    }

    # cleanup: permanently delete item from all dynamodbs
    $table->permanent_delete($node);
};

subtest 'sync: create new records' => sub {
    my %item = (
        node   => $node,
        flavor => $cfg->{flavor},
        region => $cfg->{region},
        zone   => $cfg->{zone},
    );

    # create item on one dynamodb
    $table->dynamodbs->[0]->put_item(
        TableName => 'server_definitions',
        Item      => {
            %item, 
            deleted      => 0,
            last_updated => DateTime->now() . "",
        },
    );

    # sync
    $table->sync_regions;

    # check that sync worked
    my $saved_items = {};
    for my $i (0, 1) {
        $saved_items->{$i} = $table->dynamodbs->[$i]->get_item(
            sub { shift },
            TableName => 'server_definitions',
            Key       => { node => $node },
        )->get();

        cmp_deeply $saved_items->{$i}, { 
            %item,
            deleted      => 0,
            last_updated => re(qr/^\d{4}-\d{2}\-\d{2}T\d{2}:\d{2}:\d{2}/),
        }, "saved server definition to dynamodb $i";
    }

    # cleanup: permanently delete item from all dynamodbs
    $table->permanent_delete($node);
};

done_testing;



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