/*
* 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:
*
*/
//USER
#include "ut_logsviewmanager.h"
#include "logsviewmanager.h"
#include "logsservicehandler.h"
#include "logsservicehandlerold.h"
#include "logsmainwindow.h"
#include "logscomponentrepository.h"
#include "logsrecentcallsview.h"
#include "logsmatchesview.h"
#include "logsdetailsview.h"
#include "hbstubs_helper.h"
#include "logscontact.h"
#include "qthighway_stub_helper.h"
#include "logsapplication.h"
//SYSTEM
#include <QtTest/QtTest>
#include <HbView.h>
#include <hbapplication.h>
#include <hbactivitymanager.h>
#include <dialpad.h>
void UT_LogsViewManager::initTestCase()
{
}
void UT_LogsViewManager::cleanupTestCase()
{
}
void UT_LogsViewManager::init()
{
mMainWindow = new LogsMainWindow();
mService = new LogsServiceHandler();
mServiceOld = new LogsServiceHandlerOld();
mLogsViewManager = new LogsViewManager(*mMainWindow, *mService, *mServiceOld);
}
void UT_LogsViewManager::cleanup()
{
delete mLogsViewManager;
mLogsViewManager = 0;
delete mService;
mService = 0;
delete mServiceOld;
mServiceOld = 0;
delete mMainWindow;
mMainWindow = 0;
LogsApplication* app = static_cast<LogsApplication*>( qApp );
app->mFeatureFakeExitEnabled = false;
app->mFeaturePreloadedEnabled = false;
}
void UT_LogsViewManager::testConstructorDestructor()
{
QVERIFY( mLogsViewManager );
QVERIFY( mLogsViewManager->mComponentsRepository );
QVERIFY( mLogsViewManager->mMainWindow.views().count() == 1 );
QVERIFY( mLogsViewManager->mMainWindow.currentView() != 0 );
QVERIFY( static_cast<LogsBaseView*>( mLogsViewManager->mMainWindow.currentView() )->viewId() == LogsRecentViewId );
QVERIFY( mLogsViewManager->mViewStack.count() == 1 );
QVERIFY( !mLogsViewManager->mComponentsRepository->model()->mRefreshCalled );
delete mLogsViewManager;
mLogsViewManager = 0;
// Contructor when activity restoring started the app
delete mMainWindow;
mMainWindow = 0;
mMainWindow = new LogsMainWindow();
HbStubHelper::setActivityReason(Hb::ActivationReasonActivity);
mLogsViewManager = new LogsViewManager(*mMainWindow, *mService, *mServiceOld);
QVERIFY( mLogsViewManager->mComponentsRepository );
QVERIFY( static_cast<LogsBaseView*>( mLogsViewManager->mMainWindow.currentView() )->viewId() == LogsRecentViewId );
QVERIFY( mLogsViewManager->mViewStack.count() == 1 );
QVERIFY( mLogsViewManager->mComponentsRepository->model()->mRefreshCalled );
HbStubHelper::reset();
// Constructor when service request started the app
delete mMainWindow;
mMainWindow = 0;
mMainWindow = new LogsMainWindow();
HbStubHelper::setActivityReason(Hb::ActivationReasonNormal);
QtHighwayStubHelper::setIsService(true);
LogsServiceHandler* handler2 = new LogsServiceHandler();
mLogsViewManager->mComponentsRepository->model()->mRefreshCalled = false;
mLogsViewManager = new LogsViewManager(*mMainWindow, *handler2, *mServiceOld);
QVERIFY( mLogsViewManager->mComponentsRepository );
QVERIFY( static_cast<LogsBaseView*>( mLogsViewManager->mMainWindow.currentView() )->viewId() == LogsRecentViewId );
QVERIFY( mLogsViewManager->mViewStack.count() == 0 ); // Waiting for signal
QVERIFY( mLogsViewManager->mComponentsRepository->model()->mRefreshCalled );
HbStubHelper::reset();
QtHighwayStubHelper::reset();
delete handler2;
}
void UT_LogsViewManager::testActivateView()
{
// Activate already active view
QVERIFY( mLogsViewManager->activateView(LogsRecentViewId) );
QVERIFY( mLogsViewManager->activateView(LogsRecentViewId) );
QCOMPARE( mLogsViewManager->mMainWindow.views().count(), 1 );
QVERIFY( mLogsViewManager->mMainWindow.currentView() ==
mLogsViewManager->mComponentsRepository->recentCallsView() );
// Activate other view
QVERIFY( mLogsViewManager->activateView(LogsDetailsViewId) );
QVERIFY( mLogsViewManager->mMainWindow.views().count() == 2 );
QVERIFY( mLogsViewManager->mMainWindow.currentView() ==
mLogsViewManager->mComponentsRepository->detailsView() );
QVERIFY( mLogsViewManager->mViewStack.at(0) ==
mLogsViewManager->mComponentsRepository->detailsView() );
// Try to activate unknown view
QVERIFY( !mLogsViewManager->activateView(LogsUnknownViewId) );
QVERIFY( mLogsViewManager->mMainWindow.views().count() == 2 );
QVERIFY( mLogsViewManager->mMainWindow.currentView() ==
mLogsViewManager->mComponentsRepository->detailsView() );
QVERIFY( mLogsViewManager->mViewStack.at(0) ==
mLogsViewManager->mComponentsRepository->detailsView() );
// Go back to previous view
QVERIFY( mLogsViewManager->activatePreviousView() );
QVERIFY( mLogsViewManager->mMainWindow.views().count() == 2 );
QVERIFY( mLogsViewManager->mMainWindow.currentView() ==
mLogsViewManager->mComponentsRepository->recentCallsView() );
QVERIFY( mLogsViewManager->mViewStack.at(0) ==
mLogsViewManager->mComponentsRepository->recentCallsView() );
}
void UT_LogsViewManager::testchangeMatchesView()
{
QtHighwayStubHelper::reset();
//Open Matches view, dialpad visible with predefined number
mLogsViewManager->changeMatchesViewViaService(QString("+123456"));
QVERIFY( mLogsViewManager->mMainWindow.currentView() ==
mLogsViewManager->mComponentsRepository->matchesView() );
QVERIFY( HbStubHelper::isWidgetRaised() );
// Contact search disabled, go to recent calls view instead
QtHighwayStubHelper::reset();
mLogsViewManager->mComponentsRepository->mModel->mPredectiveSearchStatus = 0;
QString dialString("+123456777");
mLogsViewManager->changeMatchesViewViaService(dialString);
QVERIFY( mLogsViewManager->mMainWindow.currentView() ==
mLogsViewManager->mComponentsRepository->recentCallsView() );
QVERIFY( mLogsViewManager->mComponentsRepository->mDialpad->mLineEdit->text() == dialString );
QVERIFY( HbStubHelper::isWidgetRaised() );
//Open Matches view, view stack not empty, embedded service canceled
QtHighwayStubHelper::reset();
QVERIFY( mLogsViewManager->mViewStack.count() );
mLogsViewManager->mViewStack.at(0)->mContact = new LogsContact();
mLogsViewManager->changeMatchesViewViaService(QString("+123456"));
QVERIFY( LogsContact::mServiceRequestCanceled );
QVERIFY( HbStubHelper::isWidgetRaised() );
//Open Matches view, view stack is empty, embedded service not canceled
QtHighwayStubHelper::reset();
LogsContact::reset();
mLogsViewManager->mViewStack.clear();
mLogsViewManager->changeMatchesViewViaService(QString("+123456"));
QVERIFY( !LogsContact::mServiceRequestCanceled );
QVERIFY( HbStubHelper::isWidgetRaised() );
}
void UT_LogsViewManager::testchangeRecentView()
{
QtHighwayStubHelper::reset();
QString dialString("+123456777");
mLogsViewManager->changeRecentViewViaService(XQService::LogsViewCalled, false, dialString);
QVERIFY( mLogsViewManager->mMainWindow.currentView() ==
mLogsViewManager->mComponentsRepository->recentCallsView() );
QVERIFY( mLogsViewManager->mComponentsRepository->mDialpad->mLineEdit->text() == dialString );
QVERIFY( HbStubHelper::isWidgetRaised() );
// Empty string clears dialpad input, check also that dialpad gets closed
QtHighwayStubHelper::reset();
mLogsViewManager->mComponentsRepository->mDialpad->mIsOpen = true;
mLogsViewManager->changeRecentViewViaService(XQService::LogsViewCalled, false, "");
QVERIFY( mLogsViewManager->mMainWindow.currentView() ==
mLogsViewManager->mComponentsRepository->recentCallsView() );
QVERIFY( mLogsViewManager->mComponentsRepository->mDialpad->mLineEdit->text().isEmpty() );
QVERIFY( HbStubHelper::isWidgetRaised() );
QVERIFY( !mLogsViewManager->mComponentsRepository->mDialpad->mIsOpen );
//Open recent view, view stack not empty, embedded service canceled
QtHighwayStubHelper::reset();
QVERIFY( mLogsViewManager->mViewStack.count() );
mLogsViewManager->mViewStack.at(0)->mContact = new LogsContact();
mLogsViewManager->changeRecentViewViaService(XQService::LogsViewCalled, false, "");
QVERIFY( LogsContact::mServiceRequestCanceled );
QVERIFY( HbStubHelper::isWidgetRaised() );
//Open recentt view, view stack is empty, embedded service not canceled
QtHighwayStubHelper::reset();
LogsContact::reset();
mLogsViewManager->mViewStack.clear();
mLogsViewManager->changeRecentViewViaService(XQService::LogsViewCalled, false, "");
QVERIFY( !LogsContact::mServiceRequestCanceled );
QVERIFY( HbStubHelper::isWidgetRaised() );
}
void UT_LogsViewManager::testExitApplication()
{
// Exit immediately possible, app sent to bg and data is compressed
HbStubHelper::reset();
mLogsViewManager->mComponentsRepository->model()->mCompressCalled = false;
QtHighwayStubHelper::reset();
mLogsViewManager->exitApplication();
QVERIFY( HbStubHelper::quitCalled() );
QVERIFY( QtHighwayStubHelper::utilToBackground() );
// Exit not yet possible, app sent only to bg
mLogsViewManager->mComponentsRepository->model()->mCompressCalled = false;
QtHighwayStubHelper::reset();
mLogsViewManager->mComponentsRepository->recentCallsView()->mMarkingMissedAsSeen = true;
HbStubHelper::reset();
mLogsViewManager->exitApplication();
QVERIFY( !HbStubHelper::quitCalled() );
QVERIFY( QtHighwayStubHelper::utilToBackground() );
// Simulate view allowing exit after denying it first
mLogsViewManager->mComponentsRepository->recentCallsView()->mMarkingMissedAsSeen = false;
mLogsViewManager->proceedExit();
QVERIFY( HbStubHelper::quitCalled() );
QVERIFY( !mLogsViewManager->mComponentsRepository->model()->mCompressCalled );
// Fake exit enabled, data is compressed, app hidden and activity saved
LogsApplication* app = static_cast<LogsApplication*>( qApp );
app->mFeatureFakeExitEnabled = true;
HbStubHelper::reset();
mLogsViewManager->mComponentsRepository->model()->mCompressCalled = false;
QtHighwayStubHelper::reset();
QCOMPARE( app->activityManager()->activities().count(), 0 );
mLogsViewManager->exitApplication();
QVERIFY( !HbStubHelper::quitCalled() );
QVERIFY( QtHighwayStubHelper::utilToBackground() );
QVERIFY( mLogsViewManager->mComponentsRepository->model()->mCompressCalled );
QVERIFY( HbStubHelper::isTsTaskVisibilitySet() );
QVERIFY( !HbStubHelper::tsTaskVisibility() );
QCOMPARE( app->activityManager()->activities().count(), 1 );
}
void UT_LogsViewManager::testStartingWithService()
{
// If app is started with highway service, view is not activated
// before service method call comes.
LogsMainWindow window;
window.setCurrentView(0); // clear stub static data
LogsServiceHandler service;
LogsServiceHandlerOld serviceOld;
service.mIsAppStartedUsingService = true;
LogsViewManager vm(window, service, serviceOld);
QVERIFY( vm.mComponentsRepository );
QVERIFY( vm.mMainWindow.views().count() == 0 );
QVERIFY( vm.mMainWindow.currentView() == 0 );
QVERIFY( vm.mViewStack.count() == 0 );
}
void UT_LogsViewManager::testHandleOrientationChanged()
{
mLogsViewManager->handleOrientationChanged();
}
void UT_LogsViewManager::testCompleteViewActivation()
{
// On first activation, wait that view has painted itself once
// before completing activation
mLogsViewManager->mFirstActivation = true;
mLogsViewManager->activateView(LogsRecentViewId, true, QVariant());
QVERIFY(!mLogsViewManager->mFirstActivation);
QVERIFY(mLogsViewManager->mViewActivationShowDialpad);
mLogsViewManager->completeViewActivation(); // Simulate paint completion (viewReady signal)
}
void UT_LogsViewManager::testSaveActivity()
{
mLogsViewManager->activateView(LogsRecentViewId, false, QVariant());
HbStubHelper::setActivityReason(Hb::ActivationReasonActivity);
HbApplication* hbApp = static_cast<HbApplication*>(qApp);
HbActivityManager* manager = hbApp->activityManager();
QCOMPARE( manager->activities().count(), 0 );
mLogsViewManager->saveActivity();
QCOMPARE( manager->activities().count(), 1 );
QVERIFY( !manager->activities().at(0).value(logsActivityParamShowDialpad).toBool() );
QVERIFY( manager->activities().at(0).value(logsActivityParamDialpadText).toString().isEmpty() );
QCOMPARE( manager->activities().at(0).value(logsActivityParamInternalViewId).toInt(), (int)LogsRecentViewId );
// Make sure that only one activity is reported
mLogsViewManager->mComponentsRepository->dialpad()->mIsOpen = true;
mLogsViewManager->mComponentsRepository->dialpad()->mLineEdit->setText("12345");
mLogsViewManager->saveActivity();
QCOMPARE( manager->activities().count(), 1 );
QVERIFY( manager->activities().at(0).value(logsActivityParamShowDialpad).toBool() );
QCOMPARE( manager->activities().at(0).value(logsActivityParamDialpadText).toString(), QString("12345") );
QCOMPARE( manager->activities().at(0).value(logsActivityParamInternalViewId).toInt(), (int)LogsMatchesViewId );
// No views, nothing to save
mLogsViewManager->mViewStack.clear();
mLogsViewManager->saveActivity();
QCOMPARE( manager->activities().count(), 1 );
}
void UT_LogsViewManager::testLoadActivity()
{
mLogsViewManager->mComponentsRepository->mModel->mPredectiveSearchStatus = 1;
HbStubHelper::setActivityReason(Hb::ActivationReasonActivity);
HbApplication* hbApp = static_cast<HbApplication*>(qApp);
HbActivityManager* manager = hbApp->activityManager();
// View activity loaded, no dialpad shown, nor text in it
HbStubHelper::setActivityId(logsActivityIdViewRecent);
mLogsViewManager->mComponentsRepository->dialpad()->mIsOpen = false;
mLogsViewManager->mComponentsRepository->dialpad()->mLineEdit->setText("");
QVariantHash params;
params.insert(logsActivityParamShowDialpad, false);
params.insert(logsActivityParamDialpadText, QString(""));
params.insert(logsActivityParamInternalViewId, LogsRecentViewId);
manager->addActivity(QString(), QVariant(), params);
QVERIFY( mLogsViewManager->loadActivity() );
QVERIFY( static_cast<LogsBaseView*>( mLogsViewManager->mMainWindow.currentView() )->viewId() == LogsRecentViewId );
QVERIFY( !mLogsViewManager->mComponentsRepository->dialpad()->mIsOpen );
QCOMPARE( mLogsViewManager->mComponentsRepository->dialpad()->mLineEdit->text(), QString("") );
// Other activity loaded, show dialpad with text
HbStubHelper::setActivityId(logsActivityIdViewMatches);
manager->removeActivity(QString());
QVariantHash params2;
params2.insert(logsActivityParamShowDialpad, true);
params2.insert(logsActivityParamDialpadText, QString("33333"));
params.insert(logsActivityParamInternalViewId, LogsMatchesViewId);
manager->addActivity(QString(), QVariant(), params2);
QVERIFY( mLogsViewManager->loadActivity() );
QVERIFY( static_cast<LogsBaseView*>( mLogsViewManager->mMainWindow.currentView() )->viewId() == LogsMatchesViewId );
QVERIFY( mLogsViewManager->mComponentsRepository->dialpad()->mIsOpen );
QCOMPARE( mLogsViewManager->mComponentsRepository->dialpad()->mLineEdit->text(), QString("33333") );
// View activity not loaded
HbStubHelper::setActivityId("unknownActivity");
QVERIFY( !mLogsViewManager->loadActivity() );
}
void UT_LogsViewManager::testAppGainedForeground()
{
// After foreground is gained, proceed exit does not cause exit
HbStubHelper::reset();
mLogsViewManager->activateView(LogsRecentViewId, false, QVariant());
connect( mLogsViewManager->mViewStack.at(0), SIGNAL(exitAllowed()), mLogsViewManager, SLOT(proceedExit()) );
emit mLogsViewManager->mViewStack.at(0)->exitAllowed();
QVERIFY( HbStubHelper::quitCalled() );
HbStubHelper::reset();
mLogsViewManager->mComponentsRepository->model()->mRefreshCalled = false;
mLogsViewManager->appGainedForeground();
emit mLogsViewManager->mViewStack.at(0)->exitAllowed();
QVERIFY( !HbStubHelper::quitCalled() );
QVERIFY( !mLogsViewManager->mComponentsRepository->model()->mRefreshCalled );
// Gaining foreground causes data refresh if fake exit or preloading feature is enabled
HbStubHelper::reset();
LogsApplication* app = static_cast<LogsApplication*>( qApp );
app->mFeatureFakeExitEnabled = true;
mLogsViewManager->appGainedForeground();
QVERIFY( mLogsViewManager->mComponentsRepository->model()->mRefreshCalled );
QVERIFY( HbStubHelper::isTsTaskVisibilitySet() );
QVERIFY( HbStubHelper::tsTaskVisibility() );
HbStubHelper::reset();
mLogsViewManager->mComponentsRepository->model()->mRefreshCalled = false;
app->mFeatureFakeExitEnabled = false;
app->mFeaturePreloadedEnabled = true;
mLogsViewManager->appGainedForeground();
QVERIFY( mLogsViewManager->mComponentsRepository->model()->mRefreshCalled );
QVERIFY( HbStubHelper::isTsTaskVisibilitySet() );
QVERIFY( HbStubHelper::tsTaskVisibility() );
}
void UT_LogsViewManager::testActivityRequested()
{
HbApplication* hbApp = static_cast<HbApplication*>(qApp);
HbActivityManager* manager = hbApp->activityManager();
HbStubHelper::reset();
HbStubHelper::setActivityId("unknownActivity");
mLogsViewManager->activityRequested("unknownActivity");
QVERIFY( !HbStubHelper::isWidgetRaised() );
HbStubHelper::setActivityId(logsActivityIdViewRecent);
mLogsViewManager->mComponentsRepository->dialpad()->mIsOpen = false;
mLogsViewManager->mComponentsRepository->dialpad()->mLineEdit->setText("");
QVariantHash params;
params.insert(logsActivityParamShowDialpad, false);
params.insert(logsActivityParamDialpadText, QString(""));
params.insert(logsActivityParamInternalViewId, LogsRecentViewId);
manager->addActivity(QString(), QVariant(), params);
mLogsViewManager->activityRequested(logsActivityIdViewRecent);
QVERIFY( static_cast<LogsBaseView*>( mLogsViewManager->mMainWindow.currentView() )->viewId() == LogsRecentViewId );
QVERIFY( !mLogsViewManager->mComponentsRepository->dialpad()->mIsOpen );
QCOMPARE( mLogsViewManager->mComponentsRepository->dialpad()->mLineEdit->text(), QString("") );
QVERIFY( HbStubHelper::isWidgetRaised() );
}