blob: aaf90d95468cb91cc3860ba056778c499eaf6c6f [file] [log] [blame]
Devang Patelddc68dd2010-09-13 20:42:15 +00001#!/usr/bin/perl
2#
3# This script tests debugging information generated by a compiler.
4# Input arguments
5# - Input source program. Usually this source file is decorated using
6# special comments to communicate debugger commands.
7# - Executable file. This file is generated by the compiler.
8#
9# This perl script extracts debugger commands from input source program
10# comments in a script. A debugger is used to load the executable file
11# and run the script generated from source program comments. Finally,
12# the debugger output is checked, using FileCheck, to validate
13# debugging information.
Adrian Prantle8010fa2013-09-06 18:12:01 +000014#
15# On Darwin the default is to use the llgdb.py wrapper script which
16# translates gdb commands into their lldb equivalents.
Devang Patelddc68dd2010-09-13 20:42:15 +000017
18use File::Basename;
Adrian Prantle8010fa2013-09-06 18:12:01 +000019use Config;
20use Cwd;
Devang Patelddc68dd2010-09-13 20:42:15 +000021
22my $testcase_file = $ARGV[0];
23my $executable_file = $ARGV[1];
24
25my $input_filename = basename $testcase_file;
26my $output_dir = dirname $executable_file;
27
Devang Patel42be03b2010-09-13 21:23:17 +000028my $debugger_script_file = "$output_dir/$input_filename.debugger.script";
Devang Patelddc68dd2010-09-13 20:42:15 +000029my $output_file = "$output_dir/$input_filename.gdb.output";
30
Adrian Prantle8010fa2013-09-06 18:12:01 +000031my %cmd_map = ();
32# Assume lldb to be the debugger on Darwin.
33my $use_lldb = 0;
34$use_lldb = 1 if ($Config{osname} eq "darwin");
35
Devang Patelddc68dd2010-09-13 20:42:15 +000036# Extract debugger commands from testcase. They are marked with DEBUGGER:
Eric Christopherd6d1f182012-06-26 00:28:15 +000037# at the beginning of a comment line.
Devang Patelddc68dd2010-09-13 20:42:15 +000038open(INPUT, $testcase_file);
39open(OUTPUT, ">$debugger_script_file");
40while(<INPUT>) {
41 my($line) = $_;
42 $i = index($line, "DEBUGGER:");
43 if ( $i >= 0) {
44 $l = length("DEBUGGER:");
45 $s = substr($line, $i + $l);
46 print OUTPUT "$s";
47 }
48}
49print OUTPUT "\n";
50print OUTPUT "quit\n";
51close(INPUT);
52close(OUTPUT);
53
54# setup debugger and debugger options to run a script.
55my $my_debugger = $ENV{'DEBUGGER'};
56if (!$my_debugger) {
Adrian Prantle8010fa2013-09-06 18:12:01 +000057 if ($use_lldb) {
58 my $path = dirname(Cwd::abs_path($0));
59 $my_debugger = "/usr/bin/env python $path/../tools/clang/test/debuginfo-tests/llgdb.py";
60 } else {
61 $my_debugger = "gdb";
62 }
Devang Patelddc68dd2010-09-13 20:42:15 +000063}
Adrian Prantle8010fa2013-09-06 18:12:01 +000064
65# quiet / exit after cmdline / no init file / execute script
Devang Patelddc68dd2010-09-13 20:42:15 +000066my $debugger_options = "-q -batch -n -x";
67
68# run debugger and capture output.
Eric Christopher2ce65412012-07-23 20:54:17 +000069system("$my_debugger $debugger_options $debugger_script_file $executable_file > $output_file 2>&1");
Devang Patelddc68dd2010-09-13 20:42:15 +000070
71# validate output.
72system("FileCheck", "-input-file", "$output_file", "$testcase_file");
73if ($?>>8 == 1) {
Adrian Prantl4b54f202014-02-20 19:55:44 +000074 print "Debugger output was:\n";
75 system("cat", "$output_file");
Devang Patelddc68dd2010-09-13 20:42:15 +000076 exit 1;
77}
78else {
79 exit 0;
80}