1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
/*============================================================================
**
** Source: test1.c
**
** Purpose:
** Compare a number of different strings against each other, ensure that the
** three return values are given at the appropriate times.
**
**
**==========================================================================*/
#include <palsuite.h>
typedef struct
{
int result;
char string1[50];
char string2[50];
} testCase;
testCase testCases[]=
{
{0,"Hello","Hello"},
{1,"hello","Hello"},
{-1,"Hello","hello"},
{0,"0Test","0Test"},
{0,"***???","***???"},
{0,"Testing the string for string comparison","Testing the string for "
"string comparison"},
{-1,"Testing the string for string comparison","Testing the string for "
"string comparsioa"},
{1,"Testing the string for string comparison","Testing the string for "
"comparison"},
{-1,"aaaabbbbb","aabcdefeccg"}
};
int __cdecl main(int argc, char *argv[])
{
int i = 0;
int result = 0;
/*
* Initialize the PAL
*/
if (0 != PAL_Initialize(argc, argv))
{
return FAIL;
}
/* Loop through structure and test each case */
for (i=0; i < sizeof(testCases)/sizeof(testCase); i++)
{
result = strcmp(testCases[i].string1,testCases[i].string2);
/* Compare returned value */
if( ((result == 0) && (testCases[i].result !=0)) ||
((result <0) && (testCases[i].result !=-1)) ||
((result >0) && (testCases[i].result !=1)) )
{
Fail("ERROR: strcmp returned %d instead of %d\n",
result, testCases[i].result);
}
}
PAL_Terminate();
return PASS;
}
|