Update copyright to LGPL on all files
[dyninst.git] / testsuite / src / dyninst / test1_1.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_1.C,v 1.1 2008/10/30 19:17:22 legendre Exp $
33 /*
34  *
35  * #Name: test1_1
36  * #Desc: Zero Argument Function Call
37  * #Arch: all
38  * #Dep: 
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
50 class test1_1_Mutator : public DyninstMutator {
51 public:
52   virtual test_results_t executeTest(); // override
53 };
54
55 // Factory function.
56 extern "C" DLLEXPORT TestMutator* test1_1_factory()
57 {
58   return new test1_1_Mutator();
59 }
60
61 //
62 // Start Test Case #1 - (zero arg function call)
63 //
64 test_results_t test1_1_Mutator::executeTest() {
65   const char *funcName = "test1_1_func1_1";
66   const char* testName = "zero arg function call";
67   int testNo = 1;
68
69   // Find the entry point to the procedure "func1_1"
70   
71   BPatch_Vector<BPatch_function *> found_funcs;
72   if ((NULL == appImage->findFunction(funcName, found_funcs))
73       || !found_funcs.size()) {
74     logerror("    Unable to find function %s\n", funcName);
75     return FAILED;
76   }
77   
78   if (1 < found_funcs.size()) {
79     logerror("%s[%d]:  WARNING  : found %d functions named %s.  Using the first.\n", 
80             __FILE__, __LINE__, found_funcs.size(), funcName);
81   }
82
83   BPatch_Vector<BPatch_point *> *point1_1 = found_funcs[0]->findPoint(BPatch_entry);
84
85
86   if (!point1_1 || ((*point1_1).size() == 0)) {
87     logerror("**Failed** test #%d (%s)\n", testNo,testName);
88     logerror("    Unable to find entry point to \"%s.\"\n", funcName);
89     return FAILED;
90   }
91
92   BPatch_Vector<BPatch_function *> bpfv;
93   char *fn = "test1_1_call1_1";
94   if (NULL == appImage->findFunction(fn, bpfv) || !bpfv.size()
95       || NULL == bpfv[0]){
96     logerror("**Failed** test #%d (%s)\n", testNo, testName);
97     logerror("    Unable to find function %s\n", fn);
98     return FAILED;
99   }
100   BPatch_function *call1_func = bpfv[0];
101   
102   BPatch_Vector<BPatch_snippet *> call1_args;
103   BPatch_funcCallExpr call1Expr(*call1_func, call1_args);
104
105   checkCost(call1Expr);
106   appAddrSpace->insertSnippet(call1Expr, *point1_1);
107   dprintf("Inserted snippet\n");
108
109   return PASSED;
110 } // test1_1_Mutator::executeTest()