Merge 'sybase_computed_columns' into 'trunk'
[dbsrgits/DBIx-Class.git] / t / inflate / file_column.t
CommitLineData
4740bdb7 1use strict;
2use warnings;
3
4use Test::More;
5use lib qw(t/lib);
6use DBICTest;
26ddc864 7use File::Compare;
8use Path::Class qw/file/;
4740bdb7 9
10my $schema = DBICTest->init_schema();
11
5d8d8611 12plan tests => 10;
4740bdb7 13
26ddc864 14my $rs = $schema->resultset('FileColumn');
100fd57f 15my $source_file = file(__FILE__);
16my $fname = $source_file->basename;
26ddc864 17my $fh = $source_file->open('r') or die "failed to open $source_file: $!\n";
18my $fc = eval {
19 $rs->create({ file => { handle => $fh, filename => $fname } })
20};
21is ( $@, '', 'created' );
22
23$fh->close;
24
25my $storage = file(
26 $fc->column_info('file')->{file_column_path},
27 $fc->id,
28 $fc->file->{filename},
29);
30ok ( -e $storage, 'storage exists' );
31
32# read it back
33$fc = $rs->find({ id => $fc->id });
34
35is ( $fc->file->{filename}, $fname, 'filename matches' );
36ok ( compare($storage, $source_file) == 0, 'file contents matches' );
37
38# update
39my $new_fname = 'File.pm';
40my $new_source_file = file(qw/lib DBIx Class InflateColumn File.pm/);
41my $new_storage = file(
42 $fc->column_info('file')->{file_column_path},
43 $fc->id,
44 $new_fname,
45);
46$fh = $new_source_file->open('r') or die "failed to open $new_source_file: $!\n";
47
48$fc->file({ handle => $fh, filename => $new_fname });
49$fc->update;
50
51TODO: {
52 local $TODO = 'design change required';
53 ok ( ! -e $storage, 'old storage does not exist' );
54};
55
56ok ( -e $new_storage, 'new storage exists' );
57
58# read it back
59$fc = $rs->find({ id => $fc->id });
60
61is ( $fc->file->{filename}, $new_fname, 'new filname matches' );
62ok ( compare($new_storage, $new_source_file) == 0, 'new content matches' );
63
64$fc->delete;
65
66ok ( ! -e $storage, 'storage deleted' );
30a93e27 67
5d8d8611 68$fh = $source_file->openr or die "failed to open $source_file: $!\n";
69$fc = $rs->create({ file => { handle => $fh, filename => $fname } });
30a93e27 70
5d8d8611 71# read it back
72$fc->discard_changes;
30a93e27 73
5d8d8611 74$storage = file(
75 $fc->column_info('file')->{file_column_path},
76 $fc->id,
77 $fc->file->{filename},
78);
30a93e27 79
5d8d8611 80TODO: {
81 local $TODO = 'need resultset delete override to delete_all';
30a93e27 82 $rs->delete;
83 ok ( ! -e $storage, 'storage does not exist after $rs->delete' );
84};