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.
 
 
 
 

469 lines
12 KiB

/* /////////////////////////////////////////////////////////////////////////
* File: test/component/test.component.log.1/test.component.log.1.cpp
*
* Purpose: Implementation file for the test.component.log.1 project.
*
* Created: 25th November 2007
* Updated: 23rd March 2010
*
* Status: Wizard-generated
*
* License: (Licensed under the Synesis Software Open License)
*
* Copyright (c) 2007-2010, 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/backends/bec.test.h>
#include <pantheios/frontends/stock.h>
#include <pantheios/util/test/compiler_warnings_suppression.last_include.h>
/* ////////////////////////////////////////////////////////////////////// */
PANTHEIOS_EXTERN_C const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PANTHEIOS_LITERAL_STRING("test.component.log.1");
/* ////////////////////////////////////////////////////////////////////// */
#define PSTR(x) PANTHEIOS_LITERAL_STRING(x)
/* /////////////////////////////////////////////////////////////////////////
* Character encoding
*/
#ifdef PANTHEIOS_USE_WIDE_STRINGS
# define XTESTS_TEST_STRING_EQUAL XTESTS_TEST_WIDE_STRING_EQUAL
#else /* ? PANTHEIOS_USE_WIDE_STRINGS */
# define XTESTS_TEST_STRING_EQUAL XTESTS_TEST_MULTIBYTE_STRING_EQUAL
#endif /* PANTHEIOS_USE_WIDE_STRINGS */
/* /////////////////////////////////////////////////////////////////////////
* Typedefs
*/
typedef std::basic_string<PAN_CHAR_T> string_t;
/* /////////////////////////////////////////////////////////////////////////
* 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.log.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_BOOLEAN_TRUE(results.empty());
XTESTS_TEST_INTEGER_EQUAL(0u, results.size());
}
static void test_02()
{
// 1. Setup
pantheios::be::test::reset();
// 2. Create test data
pantheios::log(pantheios::notice, PSTR(""));
// 3. Verification
pantheios::be::test::Results results = pantheios::be::test::results();
XTESTS_TEST_BOOLEAN_FALSE(results.empty());
XTESTS_TEST_INTEGER_EQUAL(1u, results.size());
XTESTS_TEST_STRING_EQUAL(PSTR(""), results[0].statement);
XTESTS_TEST(pantheios::notice == results[0].severity);
}
static void test_03()
{
// 1. Setup
pantheios::be::test::reset();
// 2. Create test data
pantheios::log(pantheios::notice, PSTR("abc"));
// 3. Verification
pantheios::be::test::Results results = pantheios::be::test::results();
XTESTS_TEST_BOOLEAN_FALSE(results.empty());
XTESTS_TEST_INTEGER_EQUAL(1u, results.size());
XTESTS_TEST_STRING_EQUAL(PSTR("abc"), results[0].statement);
XTESTS_TEST(pantheios::notice == results[0].severity);
}
static void test_04()
{
// 1. Setup
pantheios::be::test::reset();
// 2. Create test data
pantheios::log(pantheios::informational, PSTR("abc"), PSTR("def"));
// 3. Verification
pantheios::be::test::Results results = pantheios::be::test::results();
XTESTS_TEST_INTEGER_EQUAL(1u, results.size());
XTESTS_TEST_STRING_EQUAL(PSTR("abcdef"), results[0].statement);
XTESTS_TEST(pantheios::informational == results[0].severity);
}
static void test_05()
{
// 1. Setup
pantheios::be::test::reset();
// 2. Create test data
pantheios::log(pantheios::informational, PSTR("abc"), PSTR("def"), PSTR("ghi"));
// 3. Verification
pantheios::be::test::Results results = pantheios::be::test::results();
XTESTS_TEST_INTEGER_EQUAL(1u, results.size());
XTESTS_TEST_STRING_EQUAL(PSTR("abcdefghi"), results[0].statement);
XTESTS_TEST(pantheios::informational == results[0].severity);
}
static void test_06()
{
// 1. Setup
pantheios::be::test::reset();
// 2. Create test data
pantheios::log(pantheios::informational, PSTR("abc"), PSTR("def"), PSTR("ghi"), PSTR("jk"), PSTR("lm"), PSTR("no"), PSTR("pq"), PSTR("rs"), PSTR("tu"), PSTR("vw"), PSTR("xy"), PSTR("z"));
// 3. Verification
pantheios::be::test::Results results = pantheios::be::test::results();
XTESTS_TEST_INTEGER_EQUAL(1u, results.size());
XTESTS_TEST_STRING_EQUAL(PSTR("abcdefghijklmnopqrstuvwxyz"), results[0].statement);
XTESTS_TEST(pantheios::informational == results[0].severity);
}
static void test_07()
{
// 1. Setup
pantheios::be::test::reset();
// 2. Create test data
pantheios::log(pantheios::informational, PSTR("a"), PSTR("b"), PSTR("c"), PSTR("d"), PSTR("e"), PSTR("f"), PSTR("g"), PSTR("h"), PSTR("i"), PSTR("j"), PSTR("k"), PSTR("l"), PSTR("m"), PSTR("n"), PSTR("o"), PSTR("p"), PSTR("q"), PSTR("r"), PSTR("s"), PSTR("t"), PSTR("u"), PSTR("v"), PSTR("w"), PSTR("x"), PSTR("y"), PSTR("z"));
// 3. Verification
pantheios::be::test::Results results = pantheios::be::test::results();
XTESTS_TEST_INTEGER_EQUAL(1u, results.size());
XTESTS_TEST_STRING_EQUAL(PSTR("abcdefghijklmnopqrstuvwxyz"), results[0].statement);
XTESTS_TEST(pantheios::informational == results[0].severity);
}
static void test_08()
{}
static void test_09()
{}
static void test_10()
{
// 1. Setup
pantheios::be::test::reset();
// 2. Create test data
pantheios::log(pantheios::informational, PSTR("a"), PSTR("b"), PSTR("c"), PSTR("d"), PSTR("e"), PSTR("f"), PSTR("g"), PSTR("h"), PSTR("i"), PSTR("j"), PSTR("k"), PSTR("l"), PSTR("m"), PSTR("n"), PSTR("o"), PSTR("p"), PSTR("q"), PSTR("r"), PSTR("s"), PSTR("t"), PSTR("u"), PSTR("v"), PSTR("w"), PSTR("x"), PSTR("y"), PSTR("z"));
pantheios::log(pantheios::informational, PSTR("A"), PSTR("B"), PSTR("C"), PSTR("D"), PSTR("E"), PSTR("F"), PSTR("G"), PSTR("H"), PSTR("I"), PSTR("J"), PSTR("K"), PSTR("L"), PSTR("M"), PSTR("N"), PSTR("O"), PSTR("P"), PSTR("Q"), PSTR("R"), PSTR("S"), PSTR("T"), PSTR("U"), PSTR("V"), PSTR("W"), PSTR("X"), PSTR("Y"), PSTR("Z"));
// 3. Verification
pantheios::be::test::Results results = pantheios::be::test::results();
XTESTS_TEST_INTEGER_EQUAL(2u, results.size());
XTESTS_TEST_STRING_EQUAL(PSTR("abcdefghijklmnopqrstuvwxyz"), results[0].statement);
XTESTS_TEST_STRING_EQUAL(PSTR("ABCDEFGHIJKLMNOPQRSTUVWXYZ"), results[1].statement);
}
static void test_11()
{
// 1. Setup
pantheios::be::test::reset();
// 2. Create test data
const size_t numEntries = 1000;
{ for(size_t i = 0; i < numEntries; ++i)
{
if(0 == (i % 2))
{
pantheios::log(pantheios::informational, PSTR("a"), PSTR("b"), PSTR("c"), PSTR("d"), PSTR("e"), PSTR("f"), PSTR("g"), PSTR("h"), PSTR("i"), PSTR("j"), PSTR("k"), PSTR("l"), PSTR("m"), PSTR("n"), PSTR("o"), PSTR("p"), PSTR("q"), PSTR("r"), PSTR("s"), PSTR("t"), PSTR("u"), PSTR("v"), PSTR("w"), PSTR("x"), PSTR("y"), PSTR("z"));
}
else
{
pantheios::log(pantheios::informational, PSTR("A"), PSTR("B"), PSTR("C"), PSTR("D"), PSTR("E"), PSTR("F"), PSTR("G"), PSTR("H"), PSTR("I"), PSTR("J"), PSTR("K"), PSTR("L"), PSTR("M"), PSTR("N"), PSTR("O"), PSTR("P"), PSTR("Q"), PSTR("R"), PSTR("S"), PSTR("T"), PSTR("U"), PSTR("V"), PSTR("W"), PSTR("X"), PSTR("Y"), PSTR("Z"));
}
}}
// 3. Verification
pantheios::be::test::Results results = pantheios::be::test::results();
XTESTS_TEST_INTEGER_EQUAL(numEntries, results.size());
{ for(size_t i = 0; i < numEntries; ++i)
{
if(0 == (i % 2))
{
XTESTS_TEST_STRING_EQUAL(PSTR("abcdefghijklmnopqrstuvwxyz"), results[i].statement);
}
else
{
XTESTS_TEST_STRING_EQUAL(PSTR("ABCDEFGHIJKLMNOPQRSTUVWXYZ"), 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
string_t msgEl1(256, '~');
string_t msgEl2(4096, '#');
pantheios::log(pantheios::informational, msgEl1, msgEl2);
// 3. Verification
pantheios::be::test::Results results = pantheios::be::test::results();
XTESTS_TEST_INTEGER_EQUAL(1u, results.size());
XTESTS_TEST_STRING_EQUAL(msgEl1 + msgEl2, results[0].statement);
XTESTS_TEST(pantheios::informational == results[0].severity);
}
static void test_22()
{
// 1. Setup
pantheios::be::test::reset();
// 2. Create test data
string_t msgEl1(2560, '~');
string_t msgEl2(40960, '#');
pantheios::log(pantheios::informational, msgEl1, msgEl2);
// 3. Verification
pantheios::be::test::Results results = pantheios::be::test::results();
XTESTS_TEST_INTEGER_EQUAL(1u, results.size());
XTESTS_TEST_STRING_EQUAL(msgEl1 + msgEl2, results[0].statement);
XTESTS_TEST(pantheios::informational == results[0].severity);
}
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 //////////////////////////// */