Data-TOON

 view release on metacpan or  search on metacpan

t/01_encode_decode.t  view on Meta::CPAN

use strict;
use Test::More 0.98;
use Data::TOON;
use JSON::PP;

# Test 1: Simple object encoding
{
    my $data = {
        id => 123,
        name => 'Alice',
        active => 1,
    };
    
    my $toon = Data::TOON->encode($data);
    ok($toon, 'encode() returns non-empty string');
    like($toon, qr/id:/, 'encoded TOON contains id key');
    like($toon, qr/name:/, 'encoded TOON contains name key');
}

# Test 2: Array of objects encoding
{
    my $data = {
        users => [
            { id => 1, name => 'Alice', role => 'admin' },
            { id => 2, name => 'Bob', role => 'user' }
        ]
    };
    
    my $toon = Data::TOON->encode($data);
    ok($toon, 'encode() with array of objects returns string');
    like($toon, qr/users\[2\]/, 'encoded TOON contains array header with length');
}

# Test 3: Simple object decoding
{
    my $toon_text = <<'TOON';
id: 123
name: Alice
active: true
TOON
    
    my $data = Data::TOON->decode($toon_text);
    ok($data, 'decode() returns data structure');
    is($data->{id}, 123, 'decoded id is correct');
    is($data->{name}, 'Alice', 'decoded name is correct');
}

# Test 4: Array decoding
{
    my $toon_text = <<'TOON';
users[2]{id,name,role}:
  1,Alice,admin
  2,Bob,user
TOON
    
    my $data = Data::TOON->decode($toon_text);
    ok($data, 'decode() with array returns data structure');
    is(ref $data->{users}, 'ARRAY', 'users is an array');
    is(scalar @{$data->{users}}, 2, 'users array has 2 elements');
}

done_testing;



( run in 1.918 second using v1.01-cache-2.11-cpan-d8267643d1d )