videocollection/videocollectionview/tsrc/testcollectionview/src/testcollectionview.cpp
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/videocollection/videocollectionview/tsrc/testcollectionview/src/testcollectionview.cpp Thu Apr 01 23:22:15 2010 +0300
@@ -0,0 +1,310 @@
+/**
+* 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: tester for methods in VideoSortFilterProxyModel
+*
+*/
+#include <hbaction.h>
+#include <qpointer.h>
+#include <hbapplication.h>
+#include <hbinstance.h>
+#include <hblabel.h>
+#include "videocollectionuiloader.h"
+#include "testcollectionview.h"
+#include "videocollectioncommon.h"
+#include "videolistview.h"
+
+#include "videolistviewdata.h"
+#include "videocollectionuiloaderdata.h"
+
+#define private public
+#include "videocollectionviewplugin.h"
+#undef private
+
+// ---------------------------------------------------------------------------
+// main
+// ---------------------------------------------------------------------------
+//
+int main(int argc, char *argv[])
+{
+ HbApplication app(argc, argv);
+ HbMainWindow window;
+
+ TestCollectionView tv;
+
+ int res;
+ if(argc > 1)
+ {
+ res = QTest::qExec(&tv, argc, argv);
+ }
+ else
+ {
+ char *pass[3];
+ pass[0] = argv[0];
+ pass[1] = "-o";
+ pass[2] = "c:\\data\\testcollectionview.txt";
+ res = QTest::qExec(&tv, 3, pass);
+ }
+
+ return res;
+}
+
+// ---------------------------------------------------------------------------
+// initTestCase
+// ---------------------------------------------------------------------------
+//
+void TestCollectionView::initTestCase()
+{
+ // nop
+}
+
+// ---------------------------------------------------------------------------
+// cleanupTestCase
+// ---------------------------------------------------------------------------
+//
+void TestCollectionView::cleanupTestCase()
+{
+ // nop
+}
+
+// ---------------------------------------------------------------------------
+// init
+// ---------------------------------------------------------------------------
+//
+void TestCollectionView::init()
+{
+ VideoCollectionUiLoaderData::reset();
+ VideoListViewData::reset();
+
+ mTestView = new VideoCollectionViewPlugin();
+ mTestView->createView();
+
+ HbMainWindow *window = hbInstance->allMainWindows().value(0);
+ if (window)
+ {
+ window->addView(mTestView->getView());
+ }
+}
+
+// ---------------------------------------------------------------------------
+// cleanup
+// ---------------------------------------------------------------------------
+//
+void TestCollectionView::cleanup()
+{
+ HbMainWindow *window = hbInstance->allMainWindows().value(0);
+ if (window)
+ {
+ QList<HbView*> views = window->views();
+ int count = views.count();
+ for (int i = 0; i < count; i++)
+ {
+ window->removeView(views.at(i));
+ }
+ }
+
+ delete mTestView;
+ mTestView = 0;
+}
+
+// ---------------------------------------------------------------------------
+// Slot: test create view
+// ---------------------------------------------------------------------------
+//
+void TestCollectionView::testCreateView()
+{
+ VideoCollectionUiLoaderData::reset();
+ VideoListViewData::reset();
+
+ VideoCollectionUiLoaderData::mFindFailure = true;
+
+ mTestView = new VideoCollectionViewPlugin();
+
+ QVERIFY( mTestView->mView == NULL );
+
+ mTestView->createView();
+
+ QVERIFY( mTestView->mView == NULL );
+
+ delete mTestView;
+
+ VideoCollectionUiLoaderData::mFindFailure = false;
+
+ mTestView = new VideoCollectionViewPlugin();
+
+ QVERIFY( mTestView->mView == NULL );
+
+ mTestView->createView();
+
+ QVERIFY( mTestView->mView != NULL );
+ QCOMPARE( VideoListViewData::mInitializeViewCount, 1 );
+ QVERIFY( mTestView->mActivated == false );
+
+ connect( this, SIGNAL(commandSignal(int)), mTestView->mView, SIGNAL(command(int)));
+ QSignalSpy commandSpy(mTestView, SIGNAL(command(int)));
+ emit commandSignal(5);
+ QCOMPARE( commandSpy.count(), 1 );
+ QList<QVariant> arguments = commandSpy.takeFirst();
+ QCOMPARE( arguments.at(0).toInt(), 5 );
+ disconnect();
+
+ VideoListView* current = mTestView->mView;
+
+ mTestView->createView();
+
+ QCOMPARE( mTestView->mView, current );
+
+ HbMainWindow *window = hbInstance->allMainWindows().value(0);
+ if (window)
+ {
+ window->addView(current);
+ }
+
+ cleanup();
+}
+
+// ---------------------------------------------------------------------------
+// Slot: test activate view
+// ---------------------------------------------------------------------------
+//
+void TestCollectionView::testActivateView()
+{
+ init();
+
+ mTestView->activateView();
+ QVERIFY( mTestView->mActivated == true );
+ QCOMPARE( VideoListViewData::mActivateViewCount, 1 );
+
+ mTestView->activateView();
+ HbAction *tmpAction = 0;
+ HbMainWindow *window = hbInstance->allMainWindows().value(0);
+ if (window)
+ {
+ tmpAction = window->softKeyAction(Hb::SecondarySoftKey);
+ }
+ QCOMPARE( VideoListViewData::mActivateViewCount, 1 );
+ QVERIFY(tmpAction != 0);
+
+ cleanup();
+}
+
+// ---------------------------------------------------------------------------
+// Slot: test deactivate view
+// ---------------------------------------------------------------------------
+//
+void TestCollectionView::testDeactivateView()
+{
+ init();
+
+ mTestView->deactivateView();
+ QCOMPARE( VideoListViewData::mDeactivateViewCount, 0 );
+ QVERIFY( mTestView->mActivated == false );
+
+ mTestView->activateView();
+
+ mTestView->deactivateView();
+ QCOMPARE( VideoListViewData::mDeactivateViewCount, 1 );
+
+ QVERIFY( mTestView->mActivated == false );
+
+ mTestView->deactivateView();
+ QCOMPARE( VideoListViewData::mDeactivateViewCount, 1 );
+ QVERIFY( mTestView->mActivated == false );
+
+ cleanup();
+}
+
+// ---------------------------------------------------------------------------
+// Slot: test destroy view
+// ---------------------------------------------------------------------------
+//
+void TestCollectionView::testDestroyView()
+{
+ init();
+
+ mTestView->activateView();
+
+ mTestView->destroyView();
+
+ QCOMPARE( VideoListViewData::mDeactivateViewCount, 1 );
+ QVERIFY( mTestView->mActivated == false );
+ QVERIFY( mTestView->mView == 0 );
+
+ mTestView->createView();
+ QVERIFY( mTestView->mView != 0 );
+ mTestView->destroyView();
+ QCOMPARE( VideoListViewData::mDeactivateViewCount, 1 );
+ QVERIFY( mTestView->mActivated == false );
+ QVERIFY( mTestView->mView == 0 );
+
+ cleanup();
+}
+
+// ---------------------------------------------------------------------------
+// Slot: test get view
+// ---------------------------------------------------------------------------
+//
+void TestCollectionView::testGetView()
+{
+ mTestView = new VideoCollectionViewPlugin();
+
+ QVERIFY( mTestView->getView() == 0 );
+ mTestView->createView();
+ QVERIFY( mTestView->getView() == mTestView->mView );
+ mTestView->activateView();
+ QVERIFY( mTestView->getView() == mTestView->mView );
+ mTestView->deactivateView();
+ QVERIFY( mTestView->getView() == mTestView->mView );
+ mTestView->destroyView();
+ QVERIFY( mTestView->getView() == 0 );
+
+ cleanup();
+}
+
+// ---------------------------------------------------------------------------
+// Slot: test get view
+// ---------------------------------------------------------------------------
+//
+void TestCollectionView::testBack()
+{
+ init();
+
+ mTestView->back();
+ QCOMPARE( VideoListViewData::mBackCount, 0 );
+ mTestView->activateView();
+ mTestView->back();
+ QCOMPARE( VideoListViewData::mBackCount, 1 );
+
+ cleanup();
+}
+
+// ---------------------------------------------------------------------------
+// Slot: test orientation change
+// ---------------------------------------------------------------------------
+//
+void TestCollectionView::testOrientationChange()
+{
+ // there's nothing to be tested yet for this.
+ // implementation is requires due inherited mpxviewplugin
+ init();
+ QVERIFY(mTestView);
+ mTestView->orientationChange(Qt::Horizontal);
+ mTestView->orientationChange(Qt::Vertical);
+
+ cleanup();
+}
+
+
+
+// End of file
+