Update copyright
[dyninst.git] / testsuite / src / dyninst / test5_6.C
1 /*
2  * Copyright (c) 1996-2011 Barton P. Miller
3  * 
4  * We provide the Paradyn Parallel Performance Tools (below
5  * described as "Paradyn") on an AS IS basis, and do not warrant its
6  * validity or performance.  We reserve the right to update, modify,
7  * or discontinue this software at any time.  We shall have no
8  * obligation to supply such updates or modifications or any other
9  * form of support to you.
10  * 
11  * By your use of Paradyn, you understand and agree that we (or any
12  * other person or entity with proprietary rights in Paradyn) are
13  * under no obligation to provide either maintenance services,
14  * update services, notices of latent defects, or correction of
15  * defects for Paradyn.
16  * 
17  * This library is free software; you can redistribute it and/or
18  * modify it under the terms of the GNU Lesser General Public
19  * License as published by the Free Software Foundation; either
20  * version 2.1 of the License, or (at your option) any later version.
21  * 
22  * This library is distributed in the hope that it will be useful,
23  * but WITHOUT ANY WARRANTY; without even the implied warranty of
24  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
25  * Lesser General Public License for more details.
26  * 
27  * You should have received a copy of the GNU Lesser General Public
28  * License along with this library; if not, write to the Free Software
29  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
30  */
31
32 // $Id: test5_6.C,v 1.1 2008/10/30 19:21:08 legendre Exp $
33 /*
34  * #Name: test5_6
35  * #Desc: Exception
36  * #Dep: 
37  * #Arch: sparc_sun_solaris2_4_test,i386_unknown_linux2_0_test,x86_64_unknown_linux2_4_test,ia64_unknown_linux2_4_test
38  * #Notes:
39  */
40
41 #include "BPatch.h"
42 #include "BPatch_Vector.h"
43 #include "BPatch_thread.h"
44 #include "BPatch_snippet.h"
45
46 #include "test_lib.h"
47
48 #include "dyninst_comp.h"
49 class test5_6_Mutator : public DyninstMutator {
50 public:
51   virtual test_results_t executeTest();
52 };
53 extern "C" DLLEXPORT TestMutator *test5_6_factory() {
54   return new test5_6_Mutator();
55 }
56
57 //  
58 // Start Test Case #6 - (exception)
59 // 
60 // static int mutatorTest(BPatch_thread *appThread, BPatch_image *appImage)
61 test_results_t test5_6_Mutator::executeTest() {
62   BPatch_Vector<BPatch_function *> bpfv;
63   char *fn2 = "exception_test::func_cpp";
64   if (NULL == appImage->findFunction(fn2, bpfv) || !bpfv.size()
65       || NULL == bpfv[0]){
66     logerror("**Failed** test #6 (exception)\n");
67     logerror("    Unable to find function %s\n", fn2);
68     return FAILED;
69   }
70   BPatch_function *f1 = bpfv[0];  
71   BPatch_Vector<BPatch_point *> *point6_1 = f1->findPoint(BPatch_subroutine);
72   assert(point6_1);
73    
74   int index = 0;
75   BPatch_function *func;
76   int bound = point6_1->size();
77   // BUG We don't check that (point6_1->size() > 0)
78   BPatch_variableExpr *testno = appImage->findVariable(*(*point6_1)[0],
79                                                        "testno");
80   if (!testno) {
81     logerror("**Failed** test #6 (exception)\n");
82     logerror("    Can't find the variable in try branch of exception statement\n");
83     return FAILED;
84   }
85
86   while (index < bound) {
87     if ((func = (*point6_1)[index]->getCalledFunction()) == NULL) {
88       index++;
89       continue;
90     }
91     char fn[256];
92     func->getName(fn, 256);
93     if (!strcmp("sample_exception::response", func->getName(fn, 256))) {
94       BPatch_Vector<BPatch_point *> *point6_2 = func->findPoint(BPatch_exit);
95       assert(point6_2);
96
97       bpfv.clear();
98       char *fn3 = "test5_6_passed";
99       if (NULL == appImage->findFunction(fn3, bpfv) || !bpfv.size()
100           || NULL == bpfv[0]){
101         logerror("**Failed** test #6 (exception)\n");
102         logerror("    Unable to find function %s\n", fn3);
103         return FAILED;
104       }
105       BPatch_function *call6_func = bpfv[0];
106   
107       BPatch_Vector<BPatch_snippet *> call6_args;
108       BPatch_constExpr expr6_0(6);
109       call6_args.push_back(&expr6_0);
110       BPatch_funcCallExpr call6Expr(*call6_func, call6_args);
111
112       checkCost(call6Expr);
113       appAddrSpace->insertSnippet(call6Expr, *point6_2);
114       return PASSED;
115     }
116     index++;
117   }
118
119   // If we get here, it's because we didn't find the call to
120   // sample_exception::response().  That's an error.
121   logerror("**Failed** test #6 (exception)\n");
122   logerror("    Can't find call to exception object method in catch block\n");
123   return FAILED; // FIXME This doesn't look right..
124 }
125
126 // External Interface
127 // extern "C" TEST_DLL_EXPORT int test5_6_mutatorMAIN(ParameterDict &param)
128 // {
129 //     BPatch *bpatch;
130 //     bpatch = (BPatch *)(param["bpatch"]->getPtr());
131 //     BPatch_thread *appThread = (BPatch_thread *)(param["appThread"]->getPtr());
132
133 //     // Get log file pointers
134 //     FILE *outlog = (FILE *)(param["outlog"]->getPtr());
135 //     FILE *errlog = (FILE *)(param["errlog"]->getPtr());
136 //     setOutputLog(outlog);
137 //     setErrorLog(errlog);
138
139 //     // Read the program's image and get an associated image object
140 //     BPatch_image *appImage = appThread->getImage();
141
142 //     // Run mutator code
143 //     return mutatorTest(appThread, appImage);
144 // }