Rename newtestsuite to testsuite
[dyninst.git] / testsuite / src / dyninst / test_lib_test7.C
1 /*
2  * Copyright (c) 1996-2004 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  * This license is for research uses.  For such uses, there is no
12  * charge. We define "research use" to mean you may freely use it
13  * inside your organization for whatever purposes you see fit. But you
14  * may not re-distribute Paradyn or parts of Paradyn, in any form
15  * source or binary (including derivatives), electronic or otherwise,
16  * to any other organization or entity without our permission.
17  * 
18  * (for other uses, please contact us at paradyn@cs.wisc.edu)
19  * 
20  * All warranties, including without limitation, any warranty of
21  * merchantability or fitness for a particular purpose, are hereby
22  * excluded.
23  * 
24  * By your use of Paradyn, you understand and agree that we (or any
25  * other person or entity with proprietary rights in Paradyn) are
26  * under no obligation to provide either maintenance services,
27  * update services, notices of latent defects, or correction of
28  * defects for Paradyn.
29  * 
30  * Even if advised of the possibility of such damages, under no
31  * circumstances shall we (or any other person or entity with
32  * proprietary rights in the software licensed hereunder) be liable
33  * to you or any third party for direct, indirect, or consequential
34  * damages of any character regardless of type of action, including,
35  * without limitation, loss of profits, loss of use, loss of good
36  * will, or computer failure or malfunction.  You agree to indemnify
37  * us (and any other person or entity with proprietary rights in the
38  * software licensed hereunder) for any and all liability it may
39  * incur to third parties resulting from your use of Paradyn.
40  */
41
42 // $Id: test_lib_test7.C,v 1.1 2008/10/30 19:21:47 legendre Exp $
43 #include "test_lib_test7.h"
44 #include "test_lib.h"
45 #include <sys/msg.h>
46
47 bool setupMessaging(int *msgid) {
48   key_t msgkey = 1234;
49
50   if((*msgid = msgget(msgkey, 0666|IPC_CREAT)) == -1) {
51     perror("Couldn't create messaging");
52     return false;
53   }
54
55   return true;
56 }
57
58 bool doError(bool *passedTest, bool cond, const char *str) {
59    if(cond == true) {
60       logerror("%s", str);
61       *passedTest = false;
62       return true;
63    }
64    return false;
65 }
66
67 const char *procName[2] = { "parent", "child" };
68 /*
69  * Given a string variable name and an expected value, lookup the varaible
70  *    in the process, and verify that the value matches.
71  *
72  */
73 bool verifyProcMemory(BPatch_thread *appThread, const char *name,
74                       int expectedVal, procType proc_type)
75 {
76    BPatch_image *appImage = appThread->getImage();
77
78    if (!appImage) {
79       dprintf("unable to locate image for %d\n", appThread->getPid());
80       return false;
81    }
82    
83    BPatch_variableExpr *var = appImage->findVariable(name);
84    if (!var) {
85       dprintf("unable to located variable %s in child\n", name);
86       return false;
87    }
88
89    int actualVal;
90    var->readValue(&actualVal);
91    
92    if (expectedVal != actualVal) {
93       logerror("*** for %s (%s), expected val = %d, but actual was %d\n",
94               name, procName[proc_type], expectedVal, actualVal);
95       return false;
96    } else {
97       dprintf("verified %s (%s) was = %d\n", name, procName[proc_type], 
98               actualVal);
99       return true;
100    }
101 }
102
103 /*
104  * Given a string variable name and an expected value, lookup the varaible
105  *    in the process, and verify that the value matches.
106  *
107  */
108 bool verifyProcMemory(const char *name, BPatch_variableExpr *var,
109                       int expectedVal, procType proc_type)
110 {
111    int actualVal;
112    var->readValue(&actualVal);
113    
114    if (expectedVal != actualVal) {
115       logerror("*** for %s (%s), expected val = %d, but actual was %d\n",
116               name, procName[proc_type], expectedVal, actualVal);
117       return false;
118    } else {
119       dprintf("verified %s (%s) was = %d\n", name, procName[proc_type], 
120               actualVal);
121       return true;
122    }
123 }
124
125 char *subTestNames[10] = {
126     "<no test # 0>",
127     "Delete snippet in parent",
128     "Delete snippet in child",
129     "Delete snippet in both parent and child",
130     "Insert snippet in child - wo inherited snippets",
131     "Add snippets to parent & child",
132     "OneTimeCode in parent & child",
133     "Memory allocation in parent & child",
134     "Memory deallocate in child",
135     "Memory deallocate in parent",
136 };
137
138 // TODO Fix this up so it's less stupid (remove the magic number, make it match
139 // better with the meaningful test names, etc.
140 void showFinalResults(bool passedTest, int i) {
141    if(passedTest==false) {
142       logerror("Failed test #%d (%s)\n", i + 4, subTestNames[i]);
143    } else {
144       logerror("Passed test #%d (%s)\n", i + 4, subTestNames[i]);
145    }
146 }