The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#! perl

use 5.014;                      # strict, unicode_strings
use warnings;
use autodie;

use lib 't/lib';
use Test::BASE;
use Test::File;
use Test::More;

use App::Cmd::Tester;

use App::GitGot;
use App::GitGot::Command::add;
use App::GitGot::Command::do;

use Capture::Tiny qw/ capture /;

use Cwd;

my $dir = Test::BASE::create_tempdir_and_chdir();
my $config = "$dir/gitgot";

for my $repo ( qw/ alpha beta / ) {
    Test::BASE::build_fake_git_repo($repo);
    my $result = test_app( 'App::GitGot' => [ 'add' , '-f' , $config  , '-D' ]);
    $result->error
      and diag("App::GitGot add -f $config -D failed: " . $result->error);
    open my $fh, '>', "$repo.txt";
    print $fh "test";
    chdir '..';
}

my $cmd = $^O eq 'MSWin32' ? 'dir' : 'ls';

@ARGV = ( qw/ do -f /, $config, '--command' , $cmd , '--all' );

my( $stdout, $stderr, $exit ) = capture {
    App::GitGot->run;
};

like $stdout  , qr/##.*alpha.*alpha\.txt/s, 'alpha is listed';
like $stdout  , qr/##.*beta.*beta\.txt/s, 'beta is listed';
is $stderr    , '' , 'nothing on stderr';

@ARGV = ( qw/ do -f /, $config, '--with_repo' , '--command' , $cmd , '--all' );

( $stdout, $stderr, $exit ) = capture {
    App::GitGot->run;
};

like $stdout  , qr/alpha: .*alpha\.txt/, 'output preprended with repo name';


chdir('/'); ## clean up temp files
done_testing();