| 1 | #!/usr/bin/perl |
|---|
| 2 | |
|---|
| 3 | use strict; |
|---|
| 4 | use lib 't/lib', 'extlib', 'lib'; |
|---|
| 5 | |
|---|
| 6 | use Data::Dumper; |
|---|
| 7 | use Test::More tests => 26; |
|---|
| 8 | |
|---|
| 9 | use MT; |
|---|
| 10 | use MT::Object; |
|---|
| 11 | |
|---|
| 12 | use vars qw( $DB_DIR $T_CFG ); |
|---|
| 13 | use MT::Test qw(:db); |
|---|
| 14 | |
|---|
| 15 | my $mt = MT->instance; # plugins are go! |
|---|
| 16 | |
|---|
| 17 | require MT::Awesome; |
|---|
| 18 | require MT::Awesome::Image; |
|---|
| 19 | |
|---|
| 20 | my $file = MT::Awesome->new; |
|---|
| 21 | my $image = MT::Awesome::Image->new; |
|---|
| 22 | |
|---|
| 23 | #ok($file->has_column('meta'), 'having meta auto-adds meta column'); |
|---|
| 24 | |
|---|
| 25 | ok($file->is_meta_column('mime_type'), 'adding mime_type metadata field reports mime_type as a meta column'); |
|---|
| 26 | ok($file->has_column('mime_type'), 'adding mime_type metadata field reports mime_type as a column'); |
|---|
| 27 | ok(!defined $file->meta('mime_type'), 'unset metadata field is undefined'); |
|---|
| 28 | |
|---|
| 29 | ok($file->meta('mime_type', 'archive/zip'), 'metadata field could be set'); |
|---|
| 30 | is($file->meta('mime_type'), 'archive/zip', 'new metadata value could be retrieved'); |
|---|
| 31 | is($file->mime_type, 'archive/zip', 'auto-installed metadata field method retrieved new value'); |
|---|
| 32 | |
|---|
| 33 | diag('saving object'); |
|---|
| 34 | ok($file->save(), 'object with metadata could be saved'); |
|---|
| 35 | diag('object saved'); |
|---|
| 36 | ok($file->id, 'object with metadata received id when saved'); |
|---|
| 37 | is($file->meta('mime_type'), 'archive/zip', 'metadata value is still set after save'); |
|---|
| 38 | |
|---|
| 39 | my $file_2 = MT::Awesome->load($file->id) |
|---|
| 40 | or diag('ERROR: ' . MT::Awesome->errstr); |
|---|
| 41 | ok($file_2, 'object with metadata could be loaded'); |
|---|
| 42 | is($file_2->meta('mime_type'), 'archive/zip', 'metadata value is correct on loaded object'); |
|---|
| 43 | |
|---|
| 44 | is($file_2->mime_type, 'archive/zip', 'metadata value as retrieved with auto-installed method is correct on loaded object'); |
|---|
| 45 | |
|---|
| 46 | #ok($file->{changed_cols}{meta}, 'setting metadata field marked meta column as changed'); |
|---|
| 47 | ok(!$file->has_meta('width'), 'metadata field on subclass did not install on superclass'); |
|---|
| 48 | |
|---|
| 49 | ok(!defined $image->width, 'auto-installed metadata field method returned undef for unset field'); |
|---|
| 50 | ok($image->width(300), 'metadata field on subclass could be set with auto-installed method'); |
|---|
| 51 | is($image->width, 300, 'auto-installed metadata field method retrieved new value for subclass'); |
|---|
| 52 | #ok($image->{changed_cols}{meta}, 'setting metadata field on subclass with auto-installed method marked meta column as changed'); |
|---|
| 53 | ok($image->has_meta('width'), 'subclass has metadata field that was declared for subclass'); |
|---|
| 54 | ok($image->has_meta('mime_type'), 'subclass has metadata field that was declared for superclass'); |
|---|
| 55 | ok($image->mime_type('image/jpeg'), 'subclass object mime type set'); |
|---|
| 56 | ok($image->save(), 'image object saved'); |
|---|
| 57 | |
|---|
| 58 | ok($image->id, 'image object with metadata received id when saved'); |
|---|
| 59 | |
|---|
| 60 | my $image_2 = MT::Awesome->load($image->id); |
|---|
| 61 | ok($image_2, 'subclass object could be loaded'); |
|---|
| 62 | is($image_2->mime_type, 'image/jpeg', 'metadata value as retrieved with auto-installed method is correct on loaded image object'); |
|---|
| 63 | |
|---|
| 64 | ok(MT::Asset::Image->has_meta('image_width'), 'MT::Asset::Image has an image_width meta column.'); |
|---|
| 65 | ok(MT::Entry->has_meta, 'MT::Entry has a meta support.'); |
|---|
| 66 | ok(MT::Page->has_meta, 'MT::Page has a meta support.'); |
|---|
| 67 | |
|---|