The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use strict;
use warnings;

use Test::More;

use lib qw(t/lib);
use DBICTest;

my $schema = DBICTest->init_schema();

my $rs_with_avg = $schema->resultset('CD')->search({}, {
  '+columns' => { avg_year => $schema->resultset('CD')->get_column('year')->func_rs('avg')->as_query },
  order_by => 'cdid',
});

for my $in_storage (1, 0) {
  my $cd = $rs_with_avg->first;

  ok ! $cd->is_column_changed('avg_year'), 'no changes';

  $cd->in_storage($in_storage);

  ok ! $cd->is_column_changed('avg_year'), 'still no changes';

  $cd->set_column( avg_year => 42 );
  $cd->set_column( avg_year => 69 );

  ok $cd->is_column_changed('avg_year'), 'changed';
  is $cd->get_column('avg_year'), 69, 'correct value'
}

done_testing;