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

use strict;

BEGIN {
	$^W = 1;
}
use Test::More;
use Test::Exception;

my @classes = (
	'PPIx::EditorTools',
	'PPIx::EditorTools::FindUnmatchedBrace',
	'PPIx::EditorTools::FindVariableDeclaration',
	'PPIx::EditorTools::IntroduceTemporaryVariable',
	'PPIx::EditorTools::RenamePackage',
	'PPIx::EditorTools::RenamePackageFromPath',
	'PPIx::EditorTools::RenameVariable',
	'PPIx::EditorTools::FindUnmatchedBrace',
	'PPIx::EditorTools::Outline',
	'PPIx::EditorTools::Lexer',
	'PPIx::EditorTools::ReturnObject',
);

my @subs =
	qw( new code ppi process_doc find_unmatched_brace get_all_variable_declarations element_depth find_token_at_location find_variable_declaration );

plan tests => 14 + @subs + 2 * @classes;

foreach my $class (@classes) {
	require_ok($class);
	my $test_object = new_ok($class);
}

use_ok( 'PPIx::EditorTools', @subs );

foreach my $subs (@subs) {
	can_ok( 'PPIx::EditorTools', $subs );
}

#TODO need more pkg tests
#######
# Testing PPIx::EditorTools->process_doc()
#######
# Check that something died - we do not care why
dies_ok { PPIx::EditorTools->process_doc() } 'expecting PPIx::EditorTools->process_doc() to die';

# check code to ppi
my @test_files = (
	't/outline/Foo.pm',
	't/outline/file1.pl',
	't/outline/file2.pl',
	't/outline/Mooclass.pm',
	't/outline/Moorole.pm',
	't/outline/Moofirst.pm',
);
my $obj = PPIx::EditorTools->new();
$obj->ppi(undef);
$obj->code(undef);
foreach my $file (@test_files) {
	my $code = do {
		open my $fh, '<', $file or die "Could not open '$file' $!";
		local $/ = undef;
		<$fh>;
	};
	ok( $obj->process_doc( code => $code ),
		"process_doc(code) from $file"
	);
}

## check ppi source
my %ppi = (
	'attributes' => [
		{   'line' => 7,
			'name' => 'balance',
		},
		{   'line' => 13,
			'name' => 'overdraft',
		},
		{   'line' => 23,
			'name' => 'name',
		},
		{   'line' => 25,
			'name' => 'account',
		},
	],
	'line'    => 3,
	'methods' => [
		{   'line' => 27,
			'name' => '_build_overdraft',
		},
	],
	'modules' => [
		{   'line' => 1,
			'name' => 'MooseX::Declare',
		},
	],
	'name'     => 'Moofirst',
	'pragmata' => [
		{   'line' => 5,
			'name' => 'version',
		},
	],
);

$obj->ppi('PPI::Document');
$obj->code(undef);
ok( $obj->process_doc(%ppi), 'process_doc(ppi)' );
## check neither ppi or code fails
$obj->ppi(undef);
$obj->code(undef);
my %case = ( one => 'ppi', two => 'code', three => 'PPI::Document', );
throws_ok { $obj->process_doc(%case) } '/arguments ppi or code required/', 'arguments ppi or code required';

#TODO add more tests
dies_ok { PPIx::EditorTools->find_unmatched_brace() } 'expecting PPIx::EditorTools->find_unmatched_brace() to die';

#TODO add more tests
dies_ok { PPIx::EditorTools->get_all_variable_declarations() }
'expecting PPIx::EditorTools->get_all_variable_declarations() to die';

#TODO add more tests
dies_ok { PPIx::EditorTools->element_depth() } 'expecting PPIx::EditorTools->element_depth() to die';

#TODO add more tests
dies_ok { PPIx::EditorTools->find_token_at_location() } 'expecting PPIx::EditorTools->find_token_at_location() to die';

#dies_ok { PPIx::EditorTools->find_variable_declaration() } 'expecting PPIx::EditorTools->find_variable_declaration() to die';