os/ossrv/genericopenlibs/cstdlib/TSTLIB/TMisc3.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
// Simple STDLIB tests.
sl@0
    15
// 
sl@0
    16
//
sl@0
    17
sl@0
    18
#include <e32test.h>
sl@0
    19
#include <e32svr.h>
sl@0
    20
#include <ctype.h>
sl@0
    21
#include <math.h>
sl@0
    22
#include <errno.h>
sl@0
    23
#include "ESTLIB.H"
sl@0
    24
sl@0
    25
//CPP file is used for C tests, because by default any console opened from a C file
sl@0
    26
//expects a key to be pressed when it is about to be closed. That makes impossible
sl@0
    27
//the creation of automated C tests.
sl@0
    28
sl@0
    29
//
sl@0
    30
// Globals
sl@0
    31
sl@0
    32
static RTest TheTest(_L("TMisc3"));
sl@0
    33
const double KPi = 3.14159265358979323846;
sl@0
    34
sl@0
    35
//
sl@0
    36
//
sl@0
    37
//Test macroses and functions
sl@0
    38
sl@0
    39
static void Check(TInt aValue, TInt aLine)
sl@0
    40
	{
sl@0
    41
	if(!aValue)
sl@0
    42
		{
sl@0
    43
		TheTest(EFalse, aLine);
sl@0
    44
		}
sl@0
    45
	}
sl@0
    46
static  void Check(TInt aValue, TInt aExpected, TInt aLine)
sl@0
    47
	{
sl@0
    48
	if(aValue != aExpected)
sl@0
    49
		{
sl@0
    50
		RDebug::Print(_L("*** Expected error: %d, got: %d\r\n"), aExpected, aValue);
sl@0
    51
		TheTest(EFalse, aLine);
sl@0
    52
		}
sl@0
    53
	}
sl@0
    54
#define TEST(arg) ::Check((arg), __LINE__)
sl@0
    55
#define TEST2(aValue, aExpected) ::Check(aValue, aExpected, __LINE__)
sl@0
    56
sl@0
    57
#define TEST_NAN (0.0/0.0)
sl@0
    58
#define TEST_POS_INFINITY (1.0/0.0)
sl@0
    59
#define TEST_NEG_INFINITY (-1.0/0.0)
sl@0
    60
sl@0
    61
//
sl@0
    62
// Tests
sl@0
    63
sl@0
    64
static void TestCType()
sl@0
    65
	{
sl@0
    66
	char c;
sl@0
    67
	for(c='a';c<='z';++c)
sl@0
    68
		{
sl@0
    69
		TEST(isalnum(c));
sl@0
    70
		TEST(isalpha(c));
sl@0
    71
		TEST(!iscntrl(c));
sl@0
    72
		TEST(!isdigit(c));
sl@0
    73
		TEST(isgraph(c));
sl@0
    74
		TEST(islower(c));
sl@0
    75
		TEST(isprint(c));
sl@0
    76
		TEST(!ispunct(c));
sl@0
    77
		TEST(!isspace(c));
sl@0
    78
		TEST(!isupper(c));
sl@0
    79
		TEST(c >= 'a' && c <= 'f' ? isxdigit(c) : !isxdigit(c));
sl@0
    80
		}
sl@0
    81
	for(c='A';c<='Z';++c)
sl@0
    82
		{
sl@0
    83
		TEST(isalnum(c));
sl@0
    84
		TEST(isalpha(c));
sl@0
    85
		TEST(!iscntrl(c));
sl@0
    86
		TEST(!isdigit(c));
sl@0
    87
		TEST(isgraph(c));
sl@0
    88
		TEST(!islower(c));
sl@0
    89
		TEST(isprint(c));
sl@0
    90
		TEST(!ispunct(c));
sl@0
    91
		TEST(!isspace(c));
sl@0
    92
		TEST(isupper(c));
sl@0
    93
		TEST(c >= 'A' && c <= 'F' ? isxdigit(c) : !isxdigit(c));
sl@0
    94
		}
sl@0
    95
	for(c='0';c<='9';++c)
sl@0
    96
		{
sl@0
    97
		TEST(isalnum(c));
sl@0
    98
		TEST(!isalpha(c));
sl@0
    99
		TEST(!iscntrl(c));
sl@0
   100
		TEST(isdigit(c));
sl@0
   101
		TEST(isgraph(c));
sl@0
   102
		TEST(!islower(c));
sl@0
   103
		TEST(isprint(c));
sl@0
   104
		TEST(!ispunct(c));
sl@0
   105
		TEST(!isspace(c));
sl@0
   106
		TEST(!isupper(c));
sl@0
   107
		TEST(isxdigit(c));
sl@0
   108
		}
sl@0
   109
	for(c=0;c<' ';++c)
sl@0
   110
		{
sl@0
   111
		TEST(!isalnum(c));
sl@0
   112
		TEST(!isalpha(c));
sl@0
   113
		TEST(iscntrl(c));
sl@0
   114
		TEST(!isdigit(c));
sl@0
   115
		TEST(!isgraph(c));
sl@0
   116
		TEST(!islower(c));
sl@0
   117
		TEST(!isprint(c));
sl@0
   118
		TEST(!ispunct(c));
sl@0
   119
		if(c != '\t' && c != '\n' && c != '\r' && c != '\v' && c != '\f')
sl@0
   120
			{
sl@0
   121
			TEST(!isspace(c));
sl@0
   122
			}
sl@0
   123
		else
sl@0
   124
			{
sl@0
   125
			TEST(isspace(c));
sl@0
   126
			}
sl@0
   127
		TEST(!isupper(c));
sl@0
   128
		}
sl@0
   129
	}
sl@0
   130
sl@0
   131
static void TestMath()
sl@0
   132
	{
sl@0
   133
	double eps = 0.000001;
sl@0
   134
sl@0
   135
	double res = fabs(21.091);
sl@0
   136
	TEST((21.091 - res) < eps);
sl@0
   137
	res = fabs(-1.91);
sl@0
   138
	TEST((res - 1.91) < eps);
sl@0
   139
sl@0
   140
	res = atan(0.0);
sl@0
   141
	TEST(fabs(res) < eps);
sl@0
   142
	// 90 degrees
sl@0
   143
	res = tan(KPi/2);
sl@0
   144
	TEST(res > 1000000000.0);
sl@0
   145
	res = atan(res);
sl@0
   146
	TEST(fabs(res - KPi/2) < eps);
sl@0
   147
	// 45 degrees
sl@0
   148
	res = tan(KPi/4);
sl@0
   149
	TEST(fabs(res - 1.0) < eps);
sl@0
   150
	res = atan(res);
sl@0
   151
	TEST(fabs(res - KPi/4) < eps);
sl@0
   152
	// 135 degrees
sl@0
   153
	res = tan((3 * KPi) / 4);
sl@0
   154
	TEST(fabs(res + 1.0) < eps);
sl@0
   155
	res = atan(res);
sl@0
   156
	TEST(fabs((KPi + res) - (3 * KPi) / 4) < eps);
sl@0
   157
sl@0
   158
	// 0 degrees
sl@0
   159
	res = cos(0.0);
sl@0
   160
	TEST(fabs(res - 1) < eps);
sl@0
   161
	// 90 degrees
sl@0
   162
	res = cos(KPi/2);
sl@0
   163
	TEST(res < eps);
sl@0
   164
	// 180 degrees
sl@0
   165
	res = cos(KPi);
sl@0
   166
	TEST(fabs(res + 1.0) < eps);
sl@0
   167
sl@0
   168
	// 0 degrees
sl@0
   169
	res = sin(0.0);
sl@0
   170
	TEST(res < eps);
sl@0
   171
	// 90 degrees
sl@0
   172
	res = sin(KPi/2);
sl@0
   173
	TEST(fabs(res - 1) < eps);
sl@0
   174
	// 180 degrees
sl@0
   175
	res = sin(KPi);
sl@0
   176
	TEST(res < eps);
sl@0
   177
sl@0
   178
	res = tanh(1.0);
sl@0
   179
	TEST(fabs(res - 0.761594) < eps);
sl@0
   180
sl@0
   181
	int exponent;
sl@0
   182
	res = frexp(0.51E+2, &exponent);
sl@0
   183
	TEST((0.51E+2 - res * pow(2.0, exponent)) < eps);
sl@0
   184
sl@0
   185
	double integer;
sl@0
   186
	res = modf(34.567, &integer);
sl@0
   187
	TEST(fabs(res - 0.567) < eps);
sl@0
   188
	TEST(fabs(integer - 34.0) < eps);
sl@0
   189
	res = modf(-35.567, &integer);
sl@0
   190
	TEST(fabs(res + 0.567) < eps);
sl@0
   191
	TEST(fabs(integer + 35.0) < eps);
sl@0
   192
sl@0
   193
	res = ceil(245.8903);
sl@0
   194
	TEST(fabs(res - 246.0) < eps);
sl@0
   195
	res = ceil(-11.91);
sl@0
   196
	TEST(fabs(res + 11.0) < eps);
sl@0
   197
sl@0
   198
	res = floor(245.8903);
sl@0
   199
	TEST(fabs(res - 245.0) < eps);
sl@0
   200
	res = floor(-11.91);
sl@0
   201
	TEST(fabs(res + 12.0) < eps);
sl@0
   202
sl@0
   203
	res = copysign(4.789, -9.001);
sl@0
   204
	TEST((res + 4.789) < eps);
sl@0
   205
	res = copysign(-4.789, 9.001);
sl@0
   206
	TEST((res - 4.789) < eps);
sl@0
   207
sl@0
   208
	}
sl@0
   209
sl@0
   210
static void TestDef113884()
sl@0
   211
	{
sl@0
   212
	int exponent;
sl@0
   213
sl@0
   214
	errno = 0;
sl@0
   215
	frexp(0.51E+2, &exponent);
sl@0
   216
	pow(2.0, exponent);
sl@0
   217
	TEST2(errno, 0);
sl@0
   218
	errno = 0;
sl@0
   219
	pow(-1.0, 0.5);
sl@0
   220
	TEST2(errno, EDOM);
sl@0
   221
	errno = 0;
sl@0
   222
	// Added 'LL' as GCC needs to know these are explicitly 'long long'
sl@0
   223
	pow(34523543434234LL , 23423432234LL);
sl@0
   224
	TEST2(errno, ERANGE);
sl@0
   225
	errno = 0;
sl@0
   226
	pow(-34523543434234LL , -23423432234LL);
sl@0
   227
	TEST2(errno, ERANGE);
sl@0
   228
sl@0
   229
	errno = 0;
sl@0
   230
	atan(0.0);
sl@0
   231
	TEST2(errno, 0);
sl@0
   232
sl@0
   233
	errno = 0;
sl@0
   234
	cos(0.0);
sl@0
   235
	TEST2(errno, 0);
sl@0
   236
sl@0
   237
	errno = 0;
sl@0
   238
	sin(0.5);
sl@0
   239
	TEST2(errno, 0);
sl@0
   240
sl@0
   241
	errno = 0;
sl@0
   242
	tan(KPi/2);
sl@0
   243
	TEST2(errno, 0);
sl@0
   244
sl@0
   245
	errno = 0;
sl@0
   246
	acos(0.5);
sl@0
   247
	TEST2(errno, 0);
sl@0
   248
	errno = 0;
sl@0
   249
	acos(HUGE_VAL);
sl@0
   250
	TEST2(errno, EDOM);
sl@0
   251
sl@0
   252
	errno = 0;
sl@0
   253
	asin(0.5);
sl@0
   254
	TEST2(errno, 0);
sl@0
   255
sl@0
   256
	errno = 0;
sl@0
   257
	exp(2);
sl@0
   258
	TEST2(errno, 0);
sl@0
   259
	errno = 0;
sl@0
   260
	exp(HUGE_VAL);
sl@0
   261
	TEST2(errno, ERANGE);
sl@0
   262
	errno = 0;
sl@0
   263
	exp(-1 * HUGE_VAL);
sl@0
   264
	TEST2(errno, ERANGE);
sl@0
   265
sl@0
   266
	errno = 0;
sl@0
   267
	log(2);
sl@0
   268
	TEST2(errno, 0);
sl@0
   269
	errno = 0;
sl@0
   270
	log(-1);
sl@0
   271
	TEST2(errno, EDOM);
sl@0
   272
	errno = 0;
sl@0
   273
	log(0);
sl@0
   274
	TEST2(errno, ERANGE);
sl@0
   275
sl@0
   276
	errno = 0;
sl@0
   277
	log10(2);
sl@0
   278
	TEST2(errno, 0);
sl@0
   279
	errno = 0;
sl@0
   280
	log10(-1);
sl@0
   281
	TEST2(errno, EDOM);
sl@0
   282
	errno = 0;
sl@0
   283
	log10(0);
sl@0
   284
	TEST2(errno, ERANGE);
sl@0
   285
sl@0
   286
	errno = 0;
sl@0
   287
	sqrt(2);
sl@0
   288
	TEST2(errno, 0);
sl@0
   289
	errno = 0;
sl@0
   290
	sqrt(-1);
sl@0
   291
	TEST2(errno, EDOM);
sl@0
   292
#ifdef __ARMCC__
sl@0
   293
#pragma diag_suppress 222  //armv5 Warning #222-D is an echo of the following test.  We want to ensure that the test reports the error as well.
sl@0
   294
#else
sl@0
   295
#pragma warning (disable: 222)  //winscw Warning #222-D is an echo of the following test.  We want to ensure that the test reports the error as well.
sl@0
   296
#endif
sl@0
   297
	errno = 0;
sl@0
   298
	sqrt(2.0 * HUGE_VAL);
sl@0
   299
	TEST2(errno, ERANGE);
sl@0
   300
#ifdef __ARMCC__
sl@0
   301
#pragma diag_default 222  //armv5 Warning #222-D turned back on.
sl@0
   302
#else
sl@0
   303
#pragma warning (default: 222)  //winscw Warning #222-D turned back on.
sl@0
   304
#endif
sl@0
   305
sl@0
   306
	errno = 0;
sl@0
   307
	atan2(2.0, 2.0);
sl@0
   308
	TEST2(errno, 0);
sl@0
   309
#pragma warning (disable: 222)  //Warning #222-D is an echo of the following test.
sl@0
   310
	errno = 0;
sl@0
   311
	atan2(0.0, 0.0);
sl@0
   312
	TEST2(errno, EDOM);
sl@0
   313
#pragma warning (default: 222)  //Warning #222-D is an echo of the following test.
sl@0
   314
sl@0
   315
	errno = 0;
sl@0
   316
	fmod(2.0, 2.0);
sl@0
   317
	TEST2(errno, 0);
sl@0
   318
	errno = 0;
sl@0
   319
	fmod(1.0, 0.0);
sl@0
   320
	TEST2(errno, EDOM);
sl@0
   321
sl@0
   322
	errno = 0;
sl@0
   323
	rint(2.129999);
sl@0
   324
	TEST2(errno, 0);
sl@0
   325
sl@0
   326
	}
sl@0
   327
sl@0
   328
sl@0
   329
//
sl@0
   330
//
sl@0
   331
sl@0
   332
static void MainL()
sl@0
   333
    {
sl@0
   334
	TheTest.Start(_L(" @SYMTestCaseID:SYSLIB-STDLIB-LEGACY-TMISC3-0001 CTYPE tests "));
sl@0
   335
	::TestCType();
sl@0
   336
sl@0
   337
	TheTest.Next(_L("MATH tests"));
sl@0
   338
	::TestMath();
sl@0
   339
sl@0
   340
	TheTest.Next(_L("MATH DEF113884 tests"));
sl@0
   341
	::TestDef113884();
sl@0
   342
sl@0
   343
	CloseSTDLIB();
sl@0
   344
	}
sl@0
   345
sl@0
   346
TInt E32Main()
sl@0
   347
	{
sl@0
   348
	__UHEAP_MARK;
sl@0
   349
sl@0
   350
	CTrapCleanup* tc = CTrapCleanup::New();
sl@0
   351
    TEST(tc != NULL);
sl@0
   352
sl@0
   353
	TheTest.Title();
sl@0
   354
    TRAPD(err, ::MainL());
sl@0
   355
	TEST2(err, KErrNone);
sl@0
   356
sl@0
   357
	TheTest.End();
sl@0
   358
	TheTest.Close();
sl@0
   359
sl@0
   360
	delete tc;
sl@0
   361
sl@0
   362
	__UHEAP_MARKEND;
sl@0
   363
sl@0
   364
	User::Heap().Check();
sl@0
   365
	return KErrNone;
sl@0
   366
	}