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.
 
 
 
 

654 lines
16 KiB

/* /////////////////////////////////////////////////////////////////////////
* File: test/unit/test.unit.fe.WindowsRegistry/test.unit.fe.WindowsRegistry.cpp
*
* Purpose: Implementation file for the test.unit.fe.WindowsRegistry project.
*
* Created: 14th May 2008
* Updated: 4th January 2011
*
* Status: Wizard-generated
*
* License: (Licensed under the Synesis Software Open License)
*
* Copyright (c) 2008-2011, Synesis Software Pty Ltd.
* All rights reserved.
*
* www: http://www.synesis.com.au/software
*
* ////////////////////////////////////////////////////////////////////// */
#include <pantheios/util/test/compiler_warnings_suppression.first_include.h>
#include <pantheios/frontends/fe.WindowsRegistry.h>
#include <pantheios/init_codes.h>
#include <xtests/xtests.h>
#include <stlsoft/stlsoft.h> /* for STLSOFT_NUM_ELEMENTS */
#include <stlsoft/conversion/integer_to_string.hpp> /* stlsoft::integer_to_string */
#include <stlsoft/synch/lock_scope.hpp> /* stlsoft::lock_scope */
#include <winstl/synch/process_mutex.hpp> /* winstl::process_mutex */
#include <winstl/registry/reg_key.hpp> /* for Windows Registry Library reg_key class */
#include <stdio.h> /* for fprintf() */
#include <stdlib.h> /* for EXIT_SUCCESS, EXIT_FAILURE */
#include <pantheios/util/test/compiler_warnings_suppression.last_include.h>
/* /////////////////////////////////////////////////////////////////////////
* 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 */
#ifndef XTESTS_TEST_NOTICE
# define XTESTS_TEST_NOTICE(x) ::OutputDebugString(PANTHEIOS_LITERAL_STRING(x))
#endif // XTESTS_TEST_NOTICE
#ifdef PSTR
# undef PSTR
#endif
#define PSTR PANTHEIOS_LITERAL_STRING
/* /////////////////////////////////////////////////////////////////////////
* Globals
*/
const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PANTHEIOS_LITERAL_STRING("test.unit.fe.WindowsRegistry");
/* /////////////////////////////////////////////////////////////////////////
* Forward declarations
*/
namespace
{
static void test_can_init(void);
static void test_cannot_init(void);
static void test_levels_in_HKCU(void);
static void test_levels_in_HKLM(void);
static void test_HKCU_overrides_HKLM(void);
static void test_star(void);
static void test_1_6(void);
static void test_1_7(void);
static void test_1_8(void);
static void test_1_9(void);
static void test_1_10(void);
static void test_1_11(void);
static void test_1_12(void);
static void test_1_13(void);
static void test_1_14(void);
static void test_1_15(void);
static void test_1_16(void);
static void test_1_17(void);
static void test_1_18(void);
static void test_cleanup(void);
} // anonymous namespace
/* /////////////////////////////////////////////////////////////////////////
* Main
*/
static int main_(int argc, char** argv)
{
// Lock out other test program instances, otherwise they'll interfere
// with each other
winstl::process_mutex mx("test.unit.fe.WindowsRegistry.MX");
stlsoft::lock_scope<winstl::process_mutex> lock(mx);
int retCode = EXIT_SUCCESS;
int verbosity = 2;
XTESTS_COMMANDLINE_PARSEVERBOSITY(argc, argv, &verbosity);
if(XTESTS_START_RUNNER("test.unit.fe.WindowsRegistry", verbosity))
{
XTESTS_RUN_CASE(test_can_init);
XTESTS_RUN_CASE(test_cannot_init);
XTESTS_RUN_CASE(test_levels_in_HKCU);
XTESTS_RUN_CASE(test_levels_in_HKLM);
XTESTS_RUN_CASE(test_HKCU_overrides_HKLM);
XTESTS_RUN_CASE(test_star);
XTESTS_RUN_CASE(test_1_6);
XTESTS_RUN_CASE(test_1_7);
XTESTS_RUN_CASE(test_1_8);
XTESTS_RUN_CASE(test_1_9);
XTESTS_RUN_CASE(test_1_10);
XTESTS_RUN_CASE(test_1_11);
XTESTS_RUN_CASE(test_1_12);
XTESTS_RUN_CASE(test_1_13);
XTESTS_RUN_CASE(test_1_14);
XTESTS_RUN_CASE(test_1_15);
XTESTS_RUN_CASE(test_1_16);
XTESTS_RUN_CASE(test_1_17);
XTESTS_RUN_CASE(test_1_18);
XTESTS_RUN_CASE(test_cleanup);
XTESTS_PRINT_RESULTS();
XTESTS_END_RUNNER_UPDATE_EXITCODE(&retCode);
}
return retCode;
}
int main(int argc, char** argv)
{
#ifdef STLSOFT_CF_EXCEPTION_SUPPORT
try
{
#endif /* STLSOFT_CF_EXCEPTION_SUPPORT */
return main_(argc, argv);
#ifdef STLSOFT_CF_EXCEPTION_SUPPORT
}
catch(std::bad_alloc&)
{
fprintf(stderr, "out of memory\n");
}
catch(std::exception& x)
{
fprintf(stderr, "exception: %s\n", x.what());
}
catch(...)
{
fprintf(stderr, "unexpected condition\n");
}
#endif /* STLSOFT_CF_EXCEPTION_SUPPORT */
return EXIT_FAILURE;
}
namespace stub
{
PANTHEIOS_CALL(void) pantheios_onBailOut3(int severity, char const* message, char const* processId);
PANTHEIOS_CALL(void) pantheios_onBailOut3(int severity, char const* message, char const* processId)
{
#if 0
fprintf(stdout, "%d: %s: %s", severity, (NULL != processId) ? processId : "", message);
fprintf(stderr, "%d: %s: %s", severity, (NULL != processId) ? processId : "", message);
#else /* ? 0 */
STLSOFT_SUPPRESS_UNUSED(severity);
STLSOFT_SUPPRESS_UNUSED(message);
STLSOFT_SUPPRESS_UNUSED(processId);
#endif /* 0 */
}
} /* namespace stub */
/* /////////////////////////////////////////////////////////////////////////
* Test function implementations
*/
namespace
{
static const PAN_CHAR_T ROOT_KEY_PATH[] = PANTHEIOS_LITERAL_STRING("SOFTWARE\\Synesis Software\\Logging Tools\\Pantheios\\fe.WindowsRegistry");
static const int s_severityLevels[] =
{
PANTHEIOS_SEV_EMERGENCY
, PANTHEIOS_SEV_ALERT
, PANTHEIOS_SEV_CRITICAL
, PANTHEIOS_SEV_ERROR
, PANTHEIOS_SEV_WARNING
, PANTHEIOS_SEV_NOTICE
, PANTHEIOS_SEV_INFORMATIONAL
, PANTHEIOS_SEV_DEBUG
};
static void ensure_HKCU(int debugLevel, int releaseLevel, int starLevel)
{
winstl::reg_key key0 = winstl::reg_key::create_key(HKEY_CURRENT_USER, ROOT_KEY_PATH);
winstl::reg_key key = key0.create_sub_key(PANTHEIOS_FE_PROCESS_IDENTITY);
if(debugLevel >= 0)
{
key.set_value(PSTR("Debug"), DWORD(debugLevel));
}
if(releaseLevel >= 0)
{
key.set_value(PSTR("Release"), DWORD(releaseLevel));
}
if(starLevel >= 0)
{
key.set_value(PSTR("*"), DWORD(starLevel));
}
}
static bool ensure_HKLM(int debugLevel, int releaseLevel, int starLevel)
{
try
{
winstl::reg_key key0 = winstl::reg_key::create_key(HKEY_LOCAL_MACHINE, ROOT_KEY_PATH);
winstl::reg_key key = key0.create_sub_key(PANTHEIOS_FE_PROCESS_IDENTITY);
if(debugLevel >= 0)
{
key.set_value(PSTR("Debug"), DWORD(debugLevel));
}
if(releaseLevel >= 0)
{
key.set_value(PSTR("Release"), DWORD(releaseLevel));
}
if(starLevel >= 0)
{
key.set_value(PSTR("*"), DWORD(starLevel));
}
return true;
}
catch(winstl::windows_exception& x)
{
if(ERROR_ACCESS_DENIED == x.get_error_code())
{
return false;
}
else
{
throw;
}
}
}
static void delete_HKCU()
{
winstl::reg_key key0 = winstl::reg_key::create_key(HKEY_CURRENT_USER, ROOT_KEY_PATH);
key0.delete_sub_key(PANTHEIOS_FE_PROCESS_IDENTITY);
}
static bool delete_HKLM()
{
try
{
winstl::reg_key key0 = winstl::reg_key::create_key(HKEY_LOCAL_MACHINE, ROOT_KEY_PATH);
key0.delete_sub_key(PANTHEIOS_FE_PROCESS_IDENTITY);
return true;
}
catch(winstl::windows_exception& x)
{
if(ERROR_ACCESS_DENIED == x.get_error_code())
{
return false;
}
else
{
throw;
}
}
}
static void test_can_init()
{
// Ensure that the HKCU key exists
ensure_HKCU(0, 0, 0);
if(!delete_HKLM())
{
XTESTS_TEST_NOTICE("could not change HKEY_LOCAL_MACHINE, so skipping test case");
return;
}
void* token;
int res;
res = pantheios_fe_init(NULL, &token);
XTESTS_TEST_INTEGER_EQUAL(PANTHEIOS_INIT_RC_SUCCESS, res);
if(PANTHEIOS_INIT_RC_SUCCESS != res)
{
char num[21];
XTESTS_TEST_FAIL_WITH_QUALIFIER("failed to initialise front-end", stlsoft::integer_to_string(&num[0], STLSOFT_NUM_ELEMENTS(num), res));
}
else
{
XTESTS_TEST_PASSED();
pantheios_fe_uninit(token);
}
}
static void test_cannot_init()
{
// Ensure that neither the HKCU key nor the HKLM key exist
delete_HKCU();
if(!delete_HKLM())
{
XTESTS_TEST_NOTICE("could not change HKEY_LOCAL_MACHINE, so skipping test case");
return;
}
void* token;
int res;
res = pantheios_fe_init(NULL, &token);
XTESTS_TEST_INTEGER_NOT_EQUAL(PANTHEIOS_INIT_RC_SUCCESS, res);
if(PANTHEIOS_INIT_RC_SUCCESS != res)
{
XTESTS_TEST_PASSED();
}
else
{
XTESTS_TEST_FAIL("unexpectedly able to initialise front-end");
pantheios_fe_uninit(token);
}
}
static void test_levels_in_HKCU()
{
// Ensure that the HKCU key exists, and has the right levels
ensure_HKCU(0xff, 0x3f, -1);
if(!delete_HKLM())
{
XTESTS_TEST_NOTICE("could not change HKEY_LOCAL_MACHINE, so skipping test case");
return;
}
static const int s_severityLevelResults[] =
{
1
, 1
, 1
, 1
, 1
, 1
#ifdef NDEBUG
, 0
, 0
#else /* ? NDEBUG */
, 1
, 1
#endif /* NDEBUG */
};
STLSOFT_STATIC_ASSERT(STLSOFT_NUM_ELEMENTS(s_severityLevels) == STLSOFT_NUM_ELEMENTS(s_severityLevelResults));
void* token;
int res;
res = pantheios_fe_init(NULL, &token);
XTESTS_TEST_INTEGER_EQUAL(PANTHEIOS_INIT_RC_SUCCESS, res);
if(PANTHEIOS_INIT_RC_SUCCESS != res)
{
char num[21];
XTESTS_TEST_FAIL_WITH_QUALIFIER("failed to initialise front-end", stlsoft::integer_to_string(&num[0], STLSOFT_NUM_ELEMENTS(num), res));
}
else
{
XTESTS_TEST_PASSED();
// Now verify the levels
{ for(size_t i = 0; i != STLSOFT_NUM_ELEMENTS(s_severityLevels); ++i)
{
int b = pantheios_fe_isSeverityLogged(token, s_severityLevels[i], 0);
XTESTS_TEST_INTEGER_EQUAL(s_severityLevelResults[i], b);
}}
pantheios_fe_uninit(token);
}
}
static void test_levels_in_HKLM()
{
// Ensure that the HKCU key exists, and has the right levels
delete_HKCU();
if(!ensure_HKLM(0xff, 0x3f, -1))
{
XTESTS_TEST_NOTICE("could not change HKEY_LOCAL_MACHINE, so skipping test case");
return;
}
static const int s_severityLevelResults[] =
{
1
, 1
, 1
, 1
, 1
, 1
#ifdef NDEBUG
, 0
, 0
#else /* ? NDEBUG */
, 1
, 1
#endif /* NDEBUG */
};
STLSOFT_STATIC_ASSERT(STLSOFT_NUM_ELEMENTS(s_severityLevels) == STLSOFT_NUM_ELEMENTS(s_severityLevelResults));
void* token;
int res;
res = pantheios_fe_init(NULL, &token);
XTESTS_TEST_INTEGER_EQUAL(PANTHEIOS_INIT_RC_SUCCESS, res);
if(PANTHEIOS_INIT_RC_SUCCESS != res)
{
char num[21];
XTESTS_TEST_FAIL_WITH_QUALIFIER("failed to initialise front-end", stlsoft::integer_to_string(&num[0], STLSOFT_NUM_ELEMENTS(num), res));
}
else
{
XTESTS_TEST_PASSED();
// Now verify the levels
{ for(size_t i = 0; i != STLSOFT_NUM_ELEMENTS(s_severityLevels); ++i)
{
int b = pantheios_fe_isSeverityLogged(token, s_severityLevels[i], 0);
XTESTS_TEST_INTEGER_EQUAL(s_severityLevelResults[i], b);
}}
pantheios_fe_uninit(token);
}
}
static void test_HKCU_overrides_HKLM()
{
// Ensure that the HKCU key exists, and has the right levels
ensure_HKCU(0xff, 0x3f, -1);
if(!ensure_HKLM(0, 0, 0))
{
XTESTS_TEST_NOTICE("could not change HKEY_LOCAL_MACHINE, so skipping test case");
return;
}
static const int s_severityLevelResults[] =
{
1
, 1
, 1
, 1
, 1
, 1
#ifdef NDEBUG
, 0
, 0
#else /* ? NDEBUG */
, 1
, 1
#endif /* NDEBUG */
};
STLSOFT_STATIC_ASSERT(STLSOFT_NUM_ELEMENTS(s_severityLevels) == STLSOFT_NUM_ELEMENTS(s_severityLevelResults));
void* token;
int res;
res = pantheios_fe_init(NULL, &token);
XTESTS_TEST_INTEGER_EQUAL(PANTHEIOS_INIT_RC_SUCCESS, res);
if(PANTHEIOS_INIT_RC_SUCCESS != res)
{
char num[21];
XTESTS_TEST_FAIL_WITH_QUALIFIER("failed to initialise front-end", stlsoft::integer_to_string(&num[0], STLSOFT_NUM_ELEMENTS(num), res));
}
else
{
XTESTS_TEST_PASSED();
// Now verify the levels
{ for(size_t i = 0; i != STLSOFT_NUM_ELEMENTS(s_severityLevels); ++i)
{
int b = pantheios_fe_isSeverityLogged(token, s_severityLevels[i], 0);
XTESTS_TEST_INTEGER_EQUAL(s_severityLevelResults[i], b);
}}
pantheios_fe_uninit(token);
}
}
static void test_star()
{
// Ensure that the HKCU key exists, and has the right levels
delete_HKCU();
ensure_HKCU(-1, -1, 0x0f);
if(!delete_HKLM())
{
XTESTS_TEST_NOTICE("could not change HKEY_LOCAL_MACHINE, so skipping test case");
return;
}
static const int s_severityLevelResults[] =
{
1
, 1
, 1
, 1
, 0
, 0
, 0
, 0
};
STLSOFT_STATIC_ASSERT(STLSOFT_NUM_ELEMENTS(s_severityLevels) == STLSOFT_NUM_ELEMENTS(s_severityLevelResults));
void* token;
int res;
res = pantheios_fe_init(NULL, &token);
XTESTS_TEST_INTEGER_EQUAL(PANTHEIOS_INIT_RC_SUCCESS, res);
if(PANTHEIOS_INIT_RC_SUCCESS != res)
{
char num[21];
XTESTS_TEST_FAIL_WITH_QUALIFIER("failed to initialise front-end", stlsoft::integer_to_string(&num[0], STLSOFT_NUM_ELEMENTS(num), res));
}
else
{
XTESTS_TEST_PASSED();
// Now verify the levels
{ for(size_t i = 0; i != STLSOFT_NUM_ELEMENTS(s_severityLevels); ++i)
{
int b = pantheios_fe_isSeverityLogged(token, s_severityLevels[i], 0);
XTESTS_TEST_INTEGER_EQUAL(s_severityLevelResults[i], b);
}}
pantheios_fe_uninit(token);
}
}
static void test_1_6()
{
}
static void test_1_7()
{
}
static void test_1_8()
{
}
static void test_1_9()
{
}
static void test_1_10()
{
}
static void test_1_11()
{
}
static void test_1_12()
{
}
static void test_1_13()
{
}
static void test_1_14()
{
}
static void test_1_15()
{
}
static void test_1_16()
{
}
static void test_1_17()
{
}
static void test_1_18()
{
}
static void test_cleanup()
{
delete_HKCU();
delete_HKLM();
XTESTS_TEST_PASSED();
}
} // anonymous namespace
/* ///////////////////////////// end of file //////////////////////////// */