logsui/logsengine/tsrc/ut_logsengine/src/ut_logscommondata.cpp
author hgs
Fri, 03 Sep 2010 14:26:05 +0300
changeset 17 90fe74753f71
parent 15 76d2cf7a585e
child 21 2f0af9ba7665
permissions -rw-r--r--
201035

/*
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:
*
*/
#include "ut_logscommondata.h"
#include "logscommondata.h"
#include "logsconfigurationparams.h"
#include <xqsettingsmanager.h>

#include <QtTest/QtTest>

void UT_LogsCommonData::initTestCase()
{
}

void UT_LogsCommonData::cleanupTestCase()
{
}


void UT_LogsCommonData::init()
{
}

void UT_LogsCommonData::cleanup()
{
}

void UT_LogsCommonData::testGetInstance()
{
    QVERIFY( &LogsCommonData::getInstance() != 0 );
    QVERIFY( &LogsCommonData::getInstance() == &LogsCommonData::getInstance() );
}

void UT_LogsCommonData::testGetContactManager()
{
    QVERIFY( &LogsCommonData::getInstance().contactManager() != 0 );
    QVERIFY( &LogsCommonData::getInstance().contactManager() == &LogsCommonData::getInstance().contactManager() );
}

void UT_LogsCommonData::testFreeCommonData()
{
    LogsCommonData* comData = &LogsCommonData::getInstance();
    QVERIFY( comData != 0 );
    LogsCommonData::freeCommonData();
}

void UT_LogsCommonData::testCurrentConfiguration()
{
    LogsConfigurationParams params;
    params.setListItemTextWidth(400);
    params.setLocaleChanged(true);
    LogsCommonData::getInstance().updateConfiguration(params);
    LogsConfigurationParams& test = LogsCommonData::getInstance().currentConfiguration();
    QVERIFY( test.listItemTextWidth() == 400 );
    QVERIFY( test.localeChanged() );
}


void UT_LogsCommonData::testClearMissedCallsCounter()
{
    // Value is changed
//    LogsCommonData::freeCommonData();
    XQSettingsManager::mFailed = false;
    XQSettingsManager::mCurrentVal = 5;
    QVERIFY( LogsCommonData::getInstance().clearMissedCallsCounter() == 0 );
    QVERIFY( XQSettingsManager::mCurrentVal == 0 );
    
    // No need to change value as it is already zero
    QVERIFY( LogsCommonData::getInstance().clearMissedCallsCounter() == 0 );
    QVERIFY( XQSettingsManager::mCurrentVal == 0 );
    
    // Fails with some error
    XQSettingsManager::mFailed = true;
    XQSettingsManager::mCurrentVal = 5;
    QVERIFY( LogsCommonData::getInstance().clearMissedCallsCounter() != 0 );
    QVERIFY( XQSettingsManager::mCurrentVal == 5 );
}

void UT_LogsCommonData::testPredictiveSearchStatus()
{    

    // Predictive search fetching failed
    LogsCommonData::freeCommonData();
    XQSettingsManager::mFailed = true;
    XQSettingsManager::mCurrentVal = 1;
    QVERIFY( LogsCommonData::getInstance().mPredictiveSearchStatus == -1 );
    QVERIFY( LogsCommonData::getInstance().predictiveSearchStatus() == -1 );
    QVERIFY( LogsCommonData::getInstance().mPredictiveSearchStatus == -1 );

    // Predictive search value asked from settings manager
    XQSettingsManager::mFailed = false;
    QVERIFY( LogsCommonData::getInstance().predictiveSearchStatus() == 1 );
    QVERIFY( LogsCommonData::getInstance().mPredictiveSearchStatus == 1 );
    
    // Predictive search asked again, local value returned
    XQSettingsManager::mCurrentVal = 2;
    QVERIFY( LogsCommonData::getInstance().predictiveSearchStatus() == 1 );
    QVERIFY( LogsCommonData::getInstance().mPredictiveSearchStatus == 1 );
}

void UT_LogsCommonData::testSetPredictiveSearch()
{
    // Value change is not allowed
    LogsCommonData::getInstance().mPredictiveSearchStatus = 0;
    QVERIFY( LogsCommonData::getInstance().setPredictiveSearch(true) == -1 );
    QVERIFY( LogsCommonData::getInstance().mPredictiveSearchStatus == 0 );
    
    // Value changed, setting predictive search On
    LogsCommonData::getInstance().mPredictiveSearchStatus = 2;
    QVERIFY( LogsCommonData::getInstance().setPredictiveSearch(true) == 0 );
    QVERIFY( LogsCommonData::getInstance().mPredictiveSearchStatus == 1 );
    QVERIFY( XQSettingsManager::mCurrentVal == 1 );
    
    // Value changed, setting predictive search Off
    LogsCommonData::getInstance().mPredictiveSearchStatus = 1;
    QVERIFY( LogsCommonData::getInstance().setPredictiveSearch(false) == 0 );
    QVERIFY( LogsCommonData::getInstance().mPredictiveSearchStatus == 2 );
    QVERIFY( XQSettingsManager::mCurrentVal == 2 );

    // Fails with some error
    XQSettingsManager::mFailed = true;
    QVERIFY( LogsCommonData::getInstance().setPredictiveSearch(true) == -1 );
    QVERIFY( LogsCommonData::getInstance().mPredictiveSearchStatus == 2 );
    QVERIFY( XQSettingsManager::mCurrentVal == 2 );
}