Update copyright to LGPL on all files
[dyninst.git] / testsuite / src / dyninst / test1_36_mutatee.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 #include "mutatee_util.h"
32
33 /* group_mutatee_boilerplate.c is prepended to this file by the make system */
34
35 /* Externally accessed function prototypes.  These must have globally unique
36  * names.  I suggest following the pattern <testname>_<function>
37  */
38
39 int test1_36_call1(int i1, int i2, int i3, int i4, int i5, int i6, int i7,
40                    int i8, int i9, int i10);
41
42 /* Global variables accessed by the mutator.  These must have globally unique
43  * names.
44  */
45
46 int test1_36_globalVariable1 = 0;
47 int test1_36_globalVariable2 = 0;
48 int test1_36_globalVariable3 = 0;
49 int test1_36_globalVariable4 = 0;
50 int test1_36_globalVariable5 = 0;
51 int test1_36_globalVariable6 = 0;
52 int test1_36_globalVariable7 = 0;
53 int test1_36_globalVariable8 = 0;
54 int test1_36_globalVariable9 = 0;
55 int test1_36_globalVariable10 = 0;
56
57 /* Internally used function prototypes.  These should be declared with the
58  * keyword static so they don't interfere with other mutatees in the group.
59  */
60
61 /* Global variables used internally by the mutatee.  These should be declared
62  * with the keyword static so they don't interfere with other mutatees in the
63  * group.
64  */
65
66 /* Function definitions follow */
67
68 /* Test #36 (callsite parameter referencing) */
69
70 int test1_36_func1() {
71    int failure = 0;
72
73    int result = test1_36_call1(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);
74
75    if(result != 55) {
76       logerror("  expecting a value of 55 from test1_36_call1, got %d\n",
77               result);
78       failure = 1;
79    }
80
81    if(test1_36_globalVariable1 != 1) {
82       logerror("   for test 36, expecting arg1 value of 1, got %d\n",
83               test1_36_globalVariable1);
84       failure = 1;      
85    }
86    if(test1_36_globalVariable2 != 2) {
87       logerror("   for test 36, expecting arg2 value of 2, got %d\n",
88               test1_36_globalVariable2);
89       failure = 1;      
90    }
91    if(test1_36_globalVariable3 != 3) {
92       logerror("   for test 36, expecting arg3 value of 3, got %d\n",
93               test1_36_globalVariable3);
94       failure = 1;      
95    }
96    if(test1_36_globalVariable4 != 4) {
97       logerror("   for test 36, expecting arg4 value of 4, got %d\n",
98               test1_36_globalVariable4);
99       failure = 1;
100    }
101    if(test1_36_globalVariable5 != 5) {
102       logerror("   for test 36, expecting arg5 value of 5, got %d\n",
103               test1_36_globalVariable5);
104       failure = 1;
105    }
106    if(test1_36_globalVariable6 != 6) {
107       logerror("   for test 36, expecting arg6 value of 6, got %d\n",
108               test1_36_globalVariable6);
109       failure = 1;
110    }
111    if(test1_36_globalVariable7 != 7) {
112       logerror("   for test 36, expecting arg7 value of 7, got %d\n",
113               test1_36_globalVariable7);
114       failure = 1;
115    }
116    if(test1_36_globalVariable8 != 8) {
117       logerror("   for test 36, expecting arg8 value of 8, got %d\n",
118               test1_36_globalVariable8);
119       failure = 1;
120    }
121    if(test1_36_globalVariable9 != 9) {
122       logerror("   for test 36, expecting arg9 value of 9, got %d\n",
123               test1_36_globalVariable9);
124       failure = 1;
125    }
126    if(test1_36_globalVariable10 != 10) {
127       logerror("   for test 36, expecting arg10 value of 10, got %d\n",
128               test1_36_globalVariable10);
129 #if defined(sparc_sun_solaris2_4_test)
130       logerror("   not marking as an error since this needs "
131               "to be implemented for sparc-sol\n");
132 #else
133       failure = 1;
134 #endif
135    }
136
137    if(failure == 0) {
138       logerror( "Passed test #36 (callsite parameter referencing)\n" );    
139       return 0; /* Test passed */
140    } else {
141       logerror( "**Failed** test #36 (callsite parameter referencing)\n");
142       return -1; /* Test failed */
143    }
144 }
145
146 int test1_36_mutatee() {
147   if (test1_36_func1() == 0) {
148     test_passes(testname);
149     return 0;
150   } else {
151     return -1;
152   }
153 }
154
155 int test1_36_call1(int i1, int i2, int i3, int i4, int i5, int i6, int i7,
156                    int i8, int i9, int i10) {
157    return i1 + i2 + i3 + i4 + i5 + i6 + i7 + i8 + i9 + i10;
158 }