You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
483 lines
12 KiB
483 lines
12 KiB
/* /////////////////////////////////////////////////////////////////////////
|
|
* File: test/component/test.component.trace.1/test.component.trace.1.cpp
|
|
*
|
|
* Purpose: Implementation file for the test.component.trace.1 project.
|
|
*
|
|
* Created: 25th November 2007
|
|
* Updated: 6th August 2012
|
|
*
|
|
* Status: Wizard-generated
|
|
*
|
|
* License: (Licensed under the Synesis Software Open License)
|
|
*
|
|
* Copyright (c) 2007-2012, Synesis Software Pty Ltd.
|
|
* All rights reserved.
|
|
*
|
|
* www: http://www.synesis.com.au/software
|
|
*
|
|
* ////////////////////////////////////////////////////////////////////// */
|
|
|
|
|
|
#include <pantheios/util/test/compiler_warnings_suppression.first_include.h>
|
|
|
|
/* xTests Header Files */
|
|
#include <xtests/xtests.h>
|
|
|
|
/* Pantheios Header Files */
|
|
#include <pantheios/pantheios.hpp>
|
|
#include <pantheios/trace.h>
|
|
#include <pantheios/backends/bec.test.h>
|
|
#include <pantheios/frontends/stock.h>
|
|
|
|
/* STLSoft Header Files */
|
|
#include <stlsoft/conversion/integer_to_string.hpp>
|
|
|
|
/* Standard C++ Header Files */
|
|
#include <string>
|
|
|
|
#include <pantheios/util/test/compiler_warnings_suppression.last_include.h>
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////
|
|
* Macros
|
|
*/
|
|
|
|
#define PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(s1, s2) XTESTS_TEST_MULTIBYTE_STRING_EQUAL((s1), (s2))
|
|
|
|
/* ////////////////////////////////////////////////////////////////////// */
|
|
|
|
PANTHEIOS_EXTERN_C PAN_CHAR_T const PANTHEIOS_FE_PROCESS_IDENTITY[] = PANTHEIOS_LITERAL_STRING("test.component.trace.1");
|
|
|
|
namespace
|
|
{
|
|
static const char THIS_FILE[] = __FILE__;
|
|
|
|
inline std::string fileline_stmt_(char const* stmt, int line)
|
|
{
|
|
char sz[21];
|
|
char const* num = stlsoft::integer_to_string(&sz[0], STLSOFT_NUM_ELEMENTS(sz), line);
|
|
std::string s(THIS_FILE);
|
|
|
|
s += '(';
|
|
s += num;
|
|
s += "): ";
|
|
s += stmt;
|
|
|
|
return s;
|
|
}
|
|
|
|
} // anonymous namespace
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////
|
|
* Forward Declarations
|
|
*/
|
|
|
|
static void test_01();
|
|
static void test_02();
|
|
static void test_03();
|
|
static void test_04();
|
|
static void test_05();
|
|
static void test_06();
|
|
static void test_07();
|
|
static void test_08();
|
|
static void test_09();
|
|
static void test_10();
|
|
static void test_11();
|
|
static void test_12();
|
|
static void test_13();
|
|
static void test_14();
|
|
static void test_15();
|
|
static void test_16();
|
|
static void test_17();
|
|
static void test_18();
|
|
static void test_19();
|
|
static void test_20();
|
|
static void test_21();
|
|
static void test_22();
|
|
static void test_23();
|
|
static void test_24();
|
|
static void test_25();
|
|
static void test_26();
|
|
static void test_27();
|
|
static void test_28();
|
|
static void test_29();
|
|
|
|
/* ////////////////////////////////////////////////////////////////////// */
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
int retCode = EXIT_SUCCESS;
|
|
int verbosity = 2;
|
|
|
|
XTESTS_COMMANDLINE_PARSEVERBOSITY(argc, argv, &verbosity);
|
|
|
|
if(XTESTS_START_RUNNER("test.component.trace.1", verbosity))
|
|
{
|
|
XTESTS_RUN_CASE(test_01);
|
|
XTESTS_RUN_CASE(test_02);
|
|
XTESTS_RUN_CASE(test_03);
|
|
XTESTS_RUN_CASE(test_04);
|
|
XTESTS_RUN_CASE(test_05);
|
|
XTESTS_RUN_CASE(test_06);
|
|
XTESTS_RUN_CASE(test_07);
|
|
XTESTS_RUN_CASE(test_08);
|
|
XTESTS_RUN_CASE(test_09);
|
|
XTESTS_RUN_CASE(test_10);
|
|
XTESTS_RUN_CASE(test_11);
|
|
XTESTS_RUN_CASE(test_12);
|
|
XTESTS_RUN_CASE(test_13);
|
|
XTESTS_RUN_CASE(test_14);
|
|
XTESTS_RUN_CASE(test_15);
|
|
XTESTS_RUN_CASE(test_16);
|
|
XTESTS_RUN_CASE(test_17);
|
|
XTESTS_RUN_CASE(test_18);
|
|
XTESTS_RUN_CASE(test_19);
|
|
XTESTS_RUN_CASE(test_20);
|
|
XTESTS_RUN_CASE(test_21);
|
|
XTESTS_RUN_CASE(test_22);
|
|
XTESTS_RUN_CASE(test_23);
|
|
XTESTS_RUN_CASE(test_24);
|
|
XTESTS_RUN_CASE(test_25);
|
|
XTESTS_RUN_CASE(test_26);
|
|
XTESTS_RUN_CASE(test_27);
|
|
XTESTS_RUN_CASE(test_28);
|
|
XTESTS_RUN_CASE(test_29);
|
|
|
|
XTESTS_PRINT_RESULTS();
|
|
|
|
XTESTS_END_RUNNER_UPDATE_EXITCODE(&retCode);
|
|
}
|
|
else
|
|
{
|
|
retCode = EXIT_FAILURE;
|
|
}
|
|
|
|
return retCode;
|
|
}
|
|
|
|
/* ////////////////////////////////////////////////////////////////////// */
|
|
|
|
static void test_01()
|
|
{
|
|
// 1. Setup
|
|
|
|
pantheios::be::test::reset();
|
|
|
|
|
|
// 2. Create test data
|
|
|
|
|
|
// 3. Verification
|
|
|
|
pantheios::be::test::Results results = pantheios::be::test::results();
|
|
|
|
XTESTS_TEST(results.empty());
|
|
XTESTS_TEST(0 == results.size());
|
|
}
|
|
|
|
static void test_02()
|
|
{
|
|
// 1. Setup
|
|
|
|
pantheios::be::test::reset();
|
|
|
|
|
|
// 2. Create test data
|
|
|
|
PANTHEIOS_TRACE_NOTICE(""); int LINE = __LINE__;
|
|
|
|
|
|
// 3. Verification
|
|
|
|
pantheios::be::test::Results results = pantheios::be::test::results();
|
|
|
|
XTESTS_TEST(!results.empty());
|
|
XTESTS_TEST(1 == results.size());
|
|
XTESTS_TEST(pantheios::notice == results[0].severity);
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_("", LINE), results[0].statement);
|
|
}
|
|
|
|
static void test_03()
|
|
{
|
|
// 1. Setup
|
|
|
|
pantheios::be::test::reset();
|
|
|
|
|
|
// 2. Create test data
|
|
|
|
PANTHEIOS_TRACE_NOTICE("abc"); int LINE = __LINE__;
|
|
|
|
|
|
// 3. Verification
|
|
|
|
pantheios::be::test::Results results = pantheios::be::test::results();
|
|
|
|
XTESTS_TEST(!results.empty());
|
|
XTESTS_TEST(1 == results.size());
|
|
XTESTS_TEST(pantheios::notice == results[0].severity);
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_("abc", LINE), results[0].statement);
|
|
}
|
|
|
|
static void test_04()
|
|
{
|
|
// 1. Setup
|
|
|
|
pantheios::be::test::reset();
|
|
|
|
|
|
// 2. Create test data
|
|
|
|
PANTHEIOS_TRACE_INFORMATIONAL("abc", "def"); int LINE = __LINE__;
|
|
|
|
|
|
|
|
// 3. Verification
|
|
|
|
pantheios::be::test::Results results = pantheios::be::test::results();
|
|
|
|
XTESTS_TEST(1 == results.size());
|
|
XTESTS_TEST(pantheios::informational == results[0].severity);
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_("abcdef", LINE), results[0].statement);
|
|
}
|
|
|
|
static void test_05()
|
|
{
|
|
// 1. Setup
|
|
|
|
pantheios::be::test::reset();
|
|
|
|
|
|
// 2. Create test data
|
|
|
|
PANTHEIOS_TRACE_INFORMATIONAL("abc", "def", "ghi"); int LINE = __LINE__;
|
|
|
|
|
|
|
|
// 3. Verification
|
|
|
|
pantheios::be::test::Results results = pantheios::be::test::results();
|
|
|
|
XTESTS_TEST(1 == results.size());
|
|
XTESTS_TEST(pantheios::informational == results[0].severity);
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_("abcdefghi", LINE), results[0].statement);
|
|
}
|
|
|
|
static void test_06()
|
|
{
|
|
// 1. Setup
|
|
|
|
pantheios::be::test::reset();
|
|
|
|
|
|
// 2. Create test data
|
|
|
|
PANTHEIOS_TRACE_INFORMATIONAL("abc", "def", "ghi", "jk", "lm", "no", "pq", "rs", "tu", "vw", "xy", "z"); int LINE = __LINE__;
|
|
|
|
|
|
|
|
// 3. Verification
|
|
|
|
pantheios::be::test::Results results = pantheios::be::test::results();
|
|
|
|
XTESTS_TEST(1 == results.size());
|
|
XTESTS_TEST(pantheios::informational == results[0].severity);
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_("abcdefghijklmnopqrstuvwxyz", LINE), results[0].statement);
|
|
}
|
|
|
|
static void test_07()
|
|
{
|
|
// 1. Setup
|
|
|
|
pantheios::be::test::reset();
|
|
|
|
|
|
// 2. Create test data
|
|
|
|
PANTHEIOS_TRACE_INFORMATIONAL("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"); int LINE = __LINE__;
|
|
|
|
|
|
|
|
// 3. Verification
|
|
|
|
pantheios::be::test::Results results = pantheios::be::test::results();
|
|
|
|
XTESTS_TEST(1 == results.size());
|
|
XTESTS_TEST(pantheios::informational == results[0].severity);
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_("abcdefghijklmnopqrstuvwxyz", LINE), results[0].statement);
|
|
}
|
|
|
|
static void test_08()
|
|
{}
|
|
|
|
static void test_09()
|
|
{}
|
|
|
|
static void test_10()
|
|
{
|
|
// 1. Setup
|
|
|
|
pantheios::be::test::reset();
|
|
|
|
|
|
// 2. Create test data
|
|
|
|
PANTHEIOS_TRACE_INFORMATIONAL("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"); int LINE1 = __LINE__;
|
|
PANTHEIOS_TRACE_INFORMATIONAL("A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"); int LINE2 = __LINE__;
|
|
|
|
|
|
|
|
// 3. Verification
|
|
|
|
pantheios::be::test::Results results = pantheios::be::test::results();
|
|
|
|
XTESTS_TEST(2 == results.size());
|
|
XTESTS_TEST(pantheios::informational == results[0].severity);
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_("abcdefghijklmnopqrstuvwxyz", LINE1), results[0].statement);
|
|
XTESTS_TEST(pantheios::informational == results[1].severity);
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_("ABCDEFGHIJKLMNOPQRSTUVWXYZ", LINE2), results[1].statement);
|
|
}
|
|
|
|
static void test_11()
|
|
{
|
|
// 1. Setup
|
|
|
|
pantheios::be::test::reset();
|
|
|
|
|
|
// 2. Create test data
|
|
const size_t numEntries = 1000;
|
|
int LINE1 = -1;
|
|
int LINE2 = -1;
|
|
|
|
{ for(size_t i = 0; i < numEntries; ++i)
|
|
{
|
|
if(0 == (i % 2))
|
|
{
|
|
PANTHEIOS_TRACE_INFORMATIONAL("a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"); LINE1 = __LINE__;
|
|
}
|
|
else
|
|
{
|
|
PANTHEIOS_TRACE_INFORMATIONAL("A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"); LINE2 = __LINE__;
|
|
}
|
|
}}
|
|
|
|
|
|
|
|
// 3. Verification
|
|
|
|
pantheios::be::test::Results results = pantheios::be::test::results();
|
|
|
|
XTESTS_TEST(numEntries == results.size());
|
|
{ for(size_t i = 0; i < numEntries; ++i)
|
|
{
|
|
XTESTS_TEST(pantheios::informational == results[i].severity);
|
|
if(0 == (i % 2))
|
|
{
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_("abcdefghijklmnopqrstuvwxyz", LINE1), results[i].statement);
|
|
}
|
|
else
|
|
{
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_("ABCDEFGHIJKLMNOPQRSTUVWXYZ", LINE2), results[i].statement);
|
|
}
|
|
}}
|
|
}
|
|
|
|
static void test_12()
|
|
{}
|
|
|
|
static void test_13()
|
|
{}
|
|
|
|
static void test_14()
|
|
{}
|
|
|
|
static void test_15()
|
|
{}
|
|
|
|
static void test_16()
|
|
{}
|
|
|
|
static void test_17()
|
|
{}
|
|
|
|
static void test_18()
|
|
{}
|
|
|
|
static void test_19()
|
|
{}
|
|
|
|
static void test_20()
|
|
{}
|
|
|
|
static void test_21()
|
|
{
|
|
// 1. Setup
|
|
|
|
pantheios::be::test::reset();
|
|
|
|
|
|
// 2. Create test data
|
|
|
|
std::string msgEl1(256, '~');
|
|
std::string msgEl2(4096, '#');
|
|
|
|
|
|
PANTHEIOS_TRACE_INFORMATIONAL(msgEl1, msgEl2); int LINE = __LINE__;
|
|
|
|
|
|
|
|
// 3. Verification
|
|
|
|
pantheios::be::test::Results results = pantheios::be::test::results();
|
|
|
|
XTESTS_TEST(1 == results.size());
|
|
XTESTS_TEST(pantheios::informational == results[0].severity);
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_((msgEl1 + msgEl2).c_str(), LINE), results[0].statement);
|
|
}
|
|
|
|
static void test_22()
|
|
{
|
|
// 1. Setup
|
|
|
|
pantheios::be::test::reset();
|
|
|
|
|
|
// 2. Create test data
|
|
|
|
std::string msgEl1(2560, '~');
|
|
std::string msgEl2(40960, '#');
|
|
|
|
PANTHEIOS_TRACE_INFORMATIONAL(msgEl1, msgEl2); int LINE = __LINE__;
|
|
|
|
|
|
// 3. Verification
|
|
|
|
pantheios::be::test::Results results = pantheios::be::test::results();
|
|
|
|
XTESTS_TEST(1 == results.size());
|
|
XTESTS_TEST(pantheios::informational == results[0].severity);
|
|
PANTHEIOS_TEST_STRING_OBJECTS_EQUAL(fileline_stmt_((msgEl1 + msgEl2).c_str(), LINE), results[0].statement);
|
|
}
|
|
|
|
static void test_23()
|
|
{}
|
|
|
|
static void test_24()
|
|
{}
|
|
|
|
static void test_25()
|
|
{}
|
|
|
|
static void test_26()
|
|
{}
|
|
|
|
static void test_27()
|
|
{}
|
|
|
|
static void test_28()
|
|
{}
|
|
|
|
static void test_29()
|
|
{}
|
|
|
|
/* ///////////////////////////// end of file //////////////////////////// */
|