Update copyright to LGPL on all files
[dyninst.git] / testsuite / src / dyninst / test1_5.C
1 /*
2  * Copyright (c) 1996-2009 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: test1_5.C,v 1.1 2008/10/30 19:19:43 legendre Exp $
33 /*
34  * #Name: test1_5
35  * #Desc: Mutator Side - If without else
36  * #Arch: all
37  * #Dep: 
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 #include "dyninst_comp.h"
48
49 class test1_5_Mutator : public DyninstMutator {
50         virtual test_results_t executeTest();
51 };
52
53 extern "C" DLLEXPORT  TestMutator *test1_5_factory() 
54 {
55         return new test1_5_Mutator();
56 }
57
58 //
59 // Start Test Case #5 - mutator side (if w.o. else)
60 //
61
62 test_results_t test1_5_Mutator::executeTest() 
63 {
64         // Find the entry point to the procedure "func5_2"
65         const char *funcName = "test1_5_func2";
66
67         BPatch_Vector<BPatch_function *> found_funcs;
68         if ((NULL == appImage->findFunction(funcName, found_funcs))
69                         || !found_funcs.size()) 
70         {
71                 logerror("    Unable to find function %s\n", funcName);
72                 return FAILED;
73         }
74
75         if (1 < found_funcs.size()) 
76         {
77                 logerror("%s[%d]:  WARNING  : found %d functions named %s.  Using the first.\n", 
78                                 __FILE__, __LINE__, found_funcs.size(), funcName);
79         }
80
81         BPatch_Vector<BPatch_point *> *point5_1 = found_funcs[0]->findPoint(BPatch_entry);  
82
83         if (!point5_1 || ((*point5_1).size() == 0)) 
84         {
85                 logerror("Unable to find entry point to \"%s\".\n", funcName);
86                 return FAILED;
87         }
88
89         const char *funcName2 = "test1_5_func1";
90         BPatch_Vector<BPatch_function *> found_funcs2;
91
92         if ((NULL == appImage->findFunction(funcName2, found_funcs2))
93                         || !found_funcs2.size()) 
94         {
95                 logerror("    Unable to find function %s\n", funcName2);
96                 return FAILED;
97         }
98
99         if (1 < found_funcs2.size()) 
100         {
101                 logerror("%s[%d]:  WARNING  : found %d functions named %s.  Using the first.\n", 
102                                 __FILE__, __LINE__, found_funcs2.size(), funcName2);
103         }
104
105         BPatch_Vector<BPatch_point *> *point5_2 = found_funcs2[0]->findPoint(BPatch_subroutine);  
106
107         if (!point5_2 || ((*point5_2).size() == 0)) 
108         {
109                 logerror("Unable to find subroutine call points in \"%s\".\n", funcName2);
110                 return FAILED;
111         }
112
113         const char *globalVar1 = "test1_5_globalVariable5_1";
114         const char *globalVar2 = "test1_5_globalVariable5_2";
115         BPatch_variableExpr *expr5_1 = findVariable (appImage, globalVar1, point5_2);
116         BPatch_variableExpr *expr5_2 = findVariable (appImage, globalVar2, point5_2);
117
118         if (!expr5_1 || !expr5_2) 
119         {
120                 logerror("**Failed** test #5 (1f w.o. else)\n");
121                 logerror("    Unable to locate variable %s or ", globalVar1);
122                 logerror("    variable %s\n", globalVar2);
123                 return FAILED;
124         }
125
126         BPatch_Vector<BPatch_snippet*> vect5_1;
127
128         // if (0 == 1) globalVariable5_1 = 52;
129         BPatch_ifExpr expr5_3(BPatch_boolExpr(BPatch_eq, BPatch_constExpr(0),
130                                 BPatch_constExpr(1)), 
131                         BPatch_arithExpr(BPatch_assign, *expr5_1,
132                                 BPatch_constExpr(52)));
133
134         // if (1 == 1) globalVariable5_2 = 53;
135         BPatch_ifExpr expr5_4(BPatch_boolExpr(BPatch_eq, BPatch_constExpr(1),
136                                 BPatch_constExpr(1)), 
137                         BPatch_arithExpr(BPatch_assign, *expr5_2,
138                                 BPatch_constExpr(53)));
139
140         vect5_1.push_back(&expr5_3);
141         vect5_1.push_back(&expr5_4);
142
143         BPatch_sequence expr5_5(vect5_1);
144         checkCost(expr5_5);
145         appAddrSpace->insertSnippet(expr5_5, *point5_1);
146
147         return PASSED;
148 }