Update copyright to LGPL on all files
[dyninst.git] / testsuite / src / dyninst / test1_18.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_18.C,v 1.1 2008/10/30 19:18:03 legendre Exp $
33 /*
34  * #Name: test1_18
35  * #Desc: Mutator Side - Read/Write a variable in the mutatee
36  * #Dep: 
37  * #Notes:
38  */
39
40 #include "BPatch.h"
41 #include "BPatch_Vector.h"
42 #include "BPatch_thread.h"
43 #include "BPatch_snippet.h"
44
45 #include "test_lib.h"
46 #include "dyninst_comp.h"
47
48 class test1_18_Mutator : public DyninstMutator {
49         virtual test_results_t executeTest();
50 };
51
52 extern "C" DLLEXPORT  TestMutator *test1_18_factory() 
53 {
54         return new test1_18_Mutator();
55 }
56
57 //
58 // Start Test Case #18 - mutator side (read/write a variable in the mutatee)
59 //
60
61 test_results_t test1_18_Mutator::executeTest() 
62 {
63         const char *funcName = "test1_18_func1";
64         BPatch_Vector<BPatch_function *> found_funcs;
65
66         if ((NULL == appImage->findFunction(funcName, found_funcs)) || !found_funcs.size()) 
67         {
68                 logerror("    Unable to find function %s\n", funcName);
69                 return FAILED;
70         }
71
72         if (1 < found_funcs.size()) 
73         {
74                 logerror("%s[%d]:  WARNING  : found %d functions named %s.  Using the first.\n", 
75                                 __FILE__, __LINE__, found_funcs.size(), funcName);
76         }
77
78         BPatch_Vector<BPatch_point *> *func18_1 = found_funcs[0]->findPoint(BPatch_subroutine);
79
80         if (!func18_1 || ((*func18_1).size() == 0)) 
81         {
82                 logerror("Unable to find entry point to \"%s\".\n", funcName);
83                 return FAILED;
84         }
85
86         const char *varName = "test1_18_globalVariable1";
87         BPatch_variableExpr *expr18_1 = findVariable(appImage, varName, func18_1);
88
89         /* Initialization must be done, because C would have done initialization at declaration */
90
91         if (expr18_1 == NULL) 
92         {
93                 logerror("**Failed** test #18 (read/write a variable in the mutatee)\n");
94                 logerror("    Unable to locate %s\n", varName);
95                 return FAILED;
96         }
97
98         int expectedReadValue = 42;
99         
100         // We can't get globals initialized with FORTRAN in time to read their non-zero values...
101         if (isMutateeFortran(appImage)) 
102         {
103           expectedReadValue = 0;
104         }
105         
106         int n;
107         expr18_1->readValue(&n);
108
109         if (n != expectedReadValue) 
110         {
111                 logerror("**Failed** test #18 (read/write a variable in the mutatee)\n");
112                 logerror("    value read from %s was %d, not %d as expected\n",
113                                 varName, n, expectedReadValue);
114                 return FAILED;
115         }
116
117         n = 17;
118         if (!expr18_1->writeValue(&n,true))
119         {
120                 logerror("%s[%]:  failed to writeValue()\n", FILE__, __LINE__);
121                 return FAILED;
122         }
123
124         return PASSED;
125 } // test1_18_Mutator::executeTest()