Add test for writing to parameters and return values
[dyninst.git] / testsuite / src / dyninst / test_write_param_mutatee.c
1 #include "mutatee_util.h"
2 #include <stdlib.h>
3
4 /* Externally accessed function prototypes.  These must have globally unique
5  * names.  I suggest following the pattern <testname>_<function>
6  */
7
8 void test_write_param_call1(long p1, long p2, long p3, long p4, long p5, long p6, long p7, long p8);
9 void test_write_param_call2(long p1, long p2, long p3, long p4, long p5, long p6, long p7, long p8);
10 int test_write_param_call3();
11
12 void test_write_param_func1();
13
14 /* Global variables accessed by the mutator.  These must have globally unique
15  * names.
16  */
17
18 /* Internally used function prototypes.  These should be declared with the
19  * keyword static so they don't interfere with other mutatees in the group.
20  */
21
22 /* Global variables used internally by the mutatee.  These should be declared
23  * with the keyword static so they don't interfere with other mutatees in the
24  * group.
25  */
26 static int test_passed = 1;
27
28 /* Function definitions follow */
29
30 void test_write_param_call1(long p1, long p2, long p3, long p4, long p5, 
31                             long p6, long p7, long p8)
32 {
33    if (p1 != 1) {
34       logerror("parameter p1 is incorrect in call1\n");
35       test_passed = 0;
36    }
37    if (p2 != 2) {
38       logerror("parameter p2 is incorrect in call1\n");
39       test_passed = 0;
40    }
41    if (p3 != 3) {
42       logerror("parameter p3 is incorrect in call1\n");
43       test_passed = 0;
44    }
45    if (p4 != 4) {
46       logerror("parameter p4 is incorrect in call1\n");
47       test_passed = 0;
48    }
49    if (p5 != 5) {
50       logerror("parameter p5 is incorrect in call1\n");
51       test_passed = 0;
52    }
53    if (p6 != 6) {
54       logerror("parameter p6 is incorrect in call1\n");
55       test_passed = 0;
56    }
57    if (p7 != 7) {
58       logerror("parameter p7 is incorrect in call1\n");
59       test_passed = 0;
60    }      
61    if (p8 != 8) {
62       logerror("parameter p8 is incorrect in call1\n");
63       test_passed = 0;
64    }      
65 }
66
67 void test_write_param_call2(long p1, long p2, long p3, long p4, long p5, long p6, long p7, long p8)
68 {
69    if (p1 != 11) {
70       logerror("parameter p1 is incorrect in call2\n");
71       test_passed = 0;
72    }
73    if (p2 != 12) {
74       logerror("parameter p2 is incorrect in call2\n");
75       test_passed = 0;
76    }
77    if (p3 != 13) {
78       logerror("parameter p3 is incorrect in call2\n");
79       test_passed = 0;
80    }
81    if (p4 != 14) {
82       logerror("parameter p4 is incorrect in call2\n");
83       test_passed = 0;
84    }
85    if (p5 != 15) {
86       logerror("parameter p5 is incorrect in call2\n");
87       test_passed = 0;
88    }
89    if (p6 != 16) {
90       logerror("parameter p6 is incorrect in call2\n");
91       test_passed = 0;
92    }
93    if (p7 != 17) {
94       logerror("parameter p7 is incorrect in call2\n");
95       test_passed = 0;
96    }      
97    if (p8 != 18) {
98       logerror("parameter p8 is incorrect in call2\n");
99       test_passed = 0;
100    }
101 }
102
103 int test_write_param_call3()
104 {
105    return 0;
106 }
107
108 int test_write_param_call4()
109 {
110    return 0;
111 }
112
113 int test_write_param_func() {
114    test_write_param_call1(0, 0, 0, 0, 0, 0, 0, 0);
115    test_write_param_call2(0, 0, 0, 0, 0, 0, 0, 0);
116
117    if (test_write_param_call3() != 20) {
118       test_passed = 0;
119       logerror("Return value for call3 was incorrect\n");
120    }
121
122    if (test_write_param_call4() != 30) {
123       test_passed = 0;
124       logerror("Return value for call4 was incorrect\n");
125    }
126
127    if (!test_passed) {
128       logerror("test_write_param failed");
129       return -1;
130    }
131    return 0;
132 }
133
134 int test_write_param_mutatee() {
135   int result;
136   result = test_write_param_func();
137   if (result != -1) {
138     test_passes(testname);
139     return 0; /* Test passed */
140   } else {
141     return -1; /* Test failed */
142   }
143 }