Minor POD spelling and link fixes
[dbsrgits/DBIx-Class.git] / t / inflate / file_column.t
CommitLineData
4740bdb7 1use strict;
3814fdad 2use warnings;
4740bdb7 3
4use Test::More;
5use lib qw(t/lib);
823c91a1 6
823c91a1 7
4740bdb7 8use DBICTest;
123df526 9use DBICTest::Schema;
26ddc864 10use File::Compare;
11use Path::Class qw/file/;
4740bdb7 12
123df526 13{
14 local $ENV{DBIC_IC_FILE_NOWARN} = 1;
15
16 package DBICTest::Schema::FileColumn;
17
18 use strict;
19 use warnings;
20 use base qw/DBICTest::BaseResult/;
21
22 use File::Temp qw/tempdir/;
23
24 __PACKAGE__->load_components (qw/InflateColumn::File/);
25 __PACKAGE__->table('file_columns');
26
27 __PACKAGE__->add_columns(
28 id => { data_type => 'integer', is_auto_increment => 1 },
29 file => {
30 data_type => 'varchar',
31 is_file_column => 1,
32 file_column_path => tempdir(CLEANUP => 1),
33 size => 255
34 }
35 );
36
37 __PACKAGE__->set_primary_key('id');
38}
39DBICTest::Schema->load_classes('FileColumn');
40
823c91a1 41my $schema = DBICTest->init_schema;
4740bdb7 42
5d8d8611 43plan tests => 10;
4740bdb7 44
26ddc864 45my $rs = $schema->resultset('FileColumn');
100fd57f 46my $source_file = file(__FILE__);
47my $fname = $source_file->basename;
26ddc864 48my $fh = $source_file->open('r') or die "failed to open $source_file: $!\n";
49my $fc = eval {
50 $rs->create({ file => { handle => $fh, filename => $fname } })
51};
52is ( $@, '', 'created' );
53
54$fh->close;
55
56my $storage = file(
57 $fc->column_info('file')->{file_column_path},
58 $fc->id,
59 $fc->file->{filename},
60);
61ok ( -e $storage, 'storage exists' );
62
63# read it back
64$fc = $rs->find({ id => $fc->id });
65
66is ( $fc->file->{filename}, $fname, 'filename matches' );
67ok ( compare($storage, $source_file) == 0, 'file contents matches' );
68
69# update
70my $new_fname = 'File.pm';
71my $new_source_file = file(qw/lib DBIx Class InflateColumn File.pm/);
72my $new_storage = file(
73 $fc->column_info('file')->{file_column_path},
74 $fc->id,
75 $new_fname,
76);
77$fh = $new_source_file->open('r') or die "failed to open $new_source_file: $!\n";
78
79$fc->file({ handle => $fh, filename => $new_fname });
80$fc->update;
81
82TODO: {
83 local $TODO = 'design change required';
84 ok ( ! -e $storage, 'old storage does not exist' );
85};
86
87ok ( -e $new_storage, 'new storage exists' );
88
89# read it back
90$fc = $rs->find({ id => $fc->id });
91
92is ( $fc->file->{filename}, $new_fname, 'new filname matches' );
93ok ( compare($new_storage, $new_source_file) == 0, 'new content matches' );
94
1239d14e 95if ($^O =~ /win32|cygwin/i) {
96 close $fc->file->{handle}; # can't delete open files on Windows
97}
26ddc864 98$fc->delete;
99
100ok ( ! -e $storage, 'storage deleted' );
30a93e27 101
5d8d8611 102$fh = $source_file->openr or die "failed to open $source_file: $!\n";
103$fc = $rs->create({ file => { handle => $fh, filename => $fname } });
30a93e27 104
5d8d8611 105# read it back
106$fc->discard_changes;
30a93e27 107
5d8d8611 108$storage = file(
109 $fc->column_info('file')->{file_column_path},
110 $fc->id,
111 $fc->file->{filename},
112);
30a93e27 113
5d8d8611 114TODO: {
115 local $TODO = 'need resultset delete override to delete_all';
30a93e27 116 $rs->delete;
117 ok ( ! -e $storage, 'storage does not exist after $rs->delete' );
118};