# t/console-expungeuserpic.t # # Test LJ::Console expunge_userpic command. # # This code was forked from the LiveJournal project owned and operated # by Live Journal, Inc. The code has been modified and expanded by # Dreamwidth Studios, LLC. These files were originally licensed under # the terms of the license supplied by Live Journal, Inc, which can # currently be found at: # # http://code.livejournal.org/trac/livejournal/browser/trunk/LICENSE-LiveJournal.txt # # In accordance with the original license, this code and all its # modifications are provided under the GNU General Public License. # A copy of that license can be found in the LICENSE file included as # part of this distribution. use strict; use warnings; use Test::More; BEGIN { $LJ::_T_CONFIG = 1; require "$ENV{LJHOME}/cgi-bin/ljlib.pl"; } use LJ::Console; use LJ::Test qw (temp_user temp_comm); local $LJ::T_NO_COMMAND_PRINT = 1; my $u = temp_user(); LJ::set_remote($u); my $run = sub { my $cmd = shift; return LJ::Console->run_commands_text($cmd); }; my $file_contents = sub { my $file = shift; open( my $fh, $file ) or die $!; my $ct = do { local $/; <$fh> }; return \$ct; }; my $upfile = "$ENV{LJHOME}/t/data/userpics/good.jpg"; die "No such file $upfile" unless -e $upfile; my $up; eval { $up = LJ::Userpic->create( $u, data => $file_contents->($upfile) ) }; if ($@) { plan skip_all => "Storage failure: $@"; exit 0; } else { plan tests => 3; } is( $run->( "expunge_userpic " . $up->url ), "error: You are not authorized to run this command." ); $u->grant_priv( "siteadmin", "userpics" ); is( $run->( "expunge_userpic " . $up->url ), "success: Userpic '" . $up->id . "' for '" . $u->user . "' expunged." ); ok( $up->state eq "X", "Userpic actually expunged." );