SF:# 3522084 : AbstractConfiguration does not support 64-bit integers

This commit is contained in:
Marian Krivos
2012-05-26 17:25:36 +00:00
parent 484510dec5
commit 7eb7176397
5 changed files with 111 additions and 1 deletions

View File

@@ -118,6 +118,31 @@ void AbstractConfigurationTest::testGetInt()
}
void AbstractConfigurationTest::testGetInt64()
{
#if defined(POCO_HAVE_INT64)
AutoPtr<AbstractConfiguration> pConf = createConfiguration();
assert (pConf->getInt64("prop4.bigint1") == 420000000000L);
assert (pConf->getInt64("prop4.bigint2") == -420000000000L);
assert (pConf->getInt64("ref2") == 42);
try
{
int x = pConf->getInt64("prop1");
x=x;
fail("not a number - must throw");
}
catch (Poco::SyntaxException&)
{
}
assert (pConf->getInt64("prop4.bigint1", 100) == 420000000000L);
assert (pConf->getInt64("prop4.bigint2", 100) == -420000000000L);
#endif //defined(POCO_HAVE_INT64)
}
void AbstractConfigurationTest::testGetDouble()
{
AutoPtr<AbstractConfiguration> pConf = createConfiguration();
@@ -220,6 +245,19 @@ void AbstractConfigurationTest::testSetInt()
}
void AbstractConfigurationTest::testSetInt64()
{
#if defined(POCO_HAVE_INT64)
AutoPtr<AbstractConfiguration> pConf = createConfiguration();
pConf->setInt64("set.bigint1", 440000000000L);
pConf->setInt64("set.bigint2", -440000000000L);
assert (pConf->getInt64("set.int1") == 440000000000L);
assert (pConf->getInt64("set.int2") == -440000000000L);
#endif //defined(POCO_HAVE_INT64)
}
void AbstractConfigurationTest::testSetDouble()
{
AutoPtr<AbstractConfiguration> pConf = createConfiguration();
@@ -371,6 +409,8 @@ Poco::AutoPtr<AbstractConfiguration> AbstractConfigurationTest::createConfigurat
pConfig->setString("prop3.string2", "bar");
pConfig->setString("prop4.int1", "42");
pConfig->setString("prop4.int2", "-42");
pConfig->setString("prop4.bigint1", "420000000000");
pConfig->setString("prop4.bigint2", "-420000000000");
pConfig->setString("prop4.hex", "0x1f");
pConfig->setString("prop4.double1", "1");
pConfig->setString("prop4.double2", "-1.5");