videoplayback/videoplaybackview/tsrc/testvideodisplayhandler/src/testvideodisplayhandler.cpp
changeset 52 e3cecb93e76a
child 59 a76e86df7ccd
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/videoplayback/videoplaybackview/tsrc/testvideodisplayhandler/src/testvideodisplayhandler.cpp	Wed Aug 18 09:50:14 2010 +0300
@@ -0,0 +1,275 @@
+/**
+* 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 Video Display Handler
+*
+*/
+
+#include <e32err.h>
+#include <w32std.h>
+#include <eikenv.h>
+
+#include <hbapplication.h>
+#include <hbinstance.h>
+#include <QDebug>
+
+#include <mpxplaybackutility.h>
+
+#include "testvideodisplayhandler.h"
+#include "../stub/inc/videobaseplaybackview.h"
+#include "../stub/inc/videoplaybackviewfiledetails.h"
+#include "mpxvideoviewwrapper.h"
+
+#define private public
+#include "mpxvideoplaybackdisplayhandler.h"
+#undef private
+
+
+// ---------------------------------------------------------------------------
+// main
+// ---------------------------------------------------------------------------
+//
+int main(int argc, char *argv[])
+{
+    HbApplication app(argc, argv);
+    HbMainWindow window;
+
+    TestVideoDisplayHandler tv;
+
+    char *pass[3];
+    pass[0] = argv[0];
+    pass[1] = "-o";
+    pass[2] = "c:\\data\\testvideodisplayhandler.txt";
+
+    int res = QTest::qExec(&tv, 3, pass);
+
+    return res;
+}
+
+
+// ---------------------------------------------------------------------------
+// init
+// ---------------------------------------------------------------------------
+//
+void TestVideoDisplayHandler::init()
+{
+    mPlaybackUtility = MMPXPlaybackUtility::UtilityL( KPbModeDefault );
+
+	  mBaseVideoView    = new VideoBasePlaybackView();
+	  mVideoViewWrapper = CMPXVideoViewWrapper::NewL( mBaseVideoView );
+
+    mDispHdlr = CMPXVideoPlaybackDisplayHandler::NewL(mPlaybackUtility, mVideoViewWrapper);
+}
+
+// ---------------------------------------------------------------------------
+// cleanup
+// ---------------------------------------------------------------------------
+//
+void TestVideoDisplayHandler::cleanup()
+{
+    if ( mPlaybackUtility )
+    {
+        mPlaybackUtility->Close();
+        mPlaybackUtility = NULL;
+    }
+
+    delete mDispHdlr;
+    mDispHdlr = NULL;
+
+    delete mVideoViewWrapper;
+    mVideoViewWrapper = NULL;
+
+    delete mBaseVideoView;
+    mBaseVideoView = NULL;
+}
+
+// ---------------------------------------------------------------------------
+// setup
+// ---------------------------------------------------------------------------
+//
+void TestVideoDisplayHandler::setup()
+{
+    init();
+
+    RWindow *window = mBaseVideoView->getWindow();
+
+    TRect displayRect = TRect( window->Position().iX,
+                               window->Position().iY,
+                               window->Position().iX + window->Size().iWidth,
+                               window->Position().iY + window->Size().iHeight );
+
+    mDispHdlr->CreateDisplayWindowL( CCoeEnv::Static()->WsSession(),
+                                     *(CCoeEnv::Static()->ScreenDevice()),
+                                     *window,
+                                     displayRect);
+
+    QCOMPARE( mDispHdlr->iWindowRect, displayRect);
+
+}
+
+
+void TestVideoDisplayHandler::testCreateDisplayWindowL()
+{
+    setup();
+
+    cleanup();
+}
+
+void TestVideoDisplayHandler::testRemoveDisplayWindow()
+{
+    setup();
+
+    mDispHdlr->RemoveDisplayWindow();
+
+    QVERIFY( mDispHdlr->iVideoContainer == NULL );
+
+    cleanup();
+}
+
+void TestVideoDisplayHandler::testHandleSurfaceCreatedMessageL()
+{
+    setup();
+
+    CMPXMessage* message = NULL;
+    TRAP_IGNORE
+    (
+        message = CMPXMessage::NewL();
+        message->SetTObjectValueL<TMPXVideoDisplayCommand>
+                    ( KMPXMediaVideoDisplayCommand, EPbMsgVideoSurfaceCreated );
+    );
+
+    mDispHdlr->HandleVideoDisplayMessageL( message );
+
+    QVERIFY( ! mDispHdlr->iSurfaceId.IsNull() );
+    QVERIFY( mDispHdlr->iViewWrapper->iAttatched );
+
+    mDispHdlr->RemoveDisplayWindow();
+    cleanup();
+}
+
+void TestVideoDisplayHandler::testHandleSurfaceChangedMessageL()
+{
+    setup();
+
+    CMPXMessage* message = NULL;
+    TRAP_IGNORE
+    (
+        message = CMPXMessage::NewL();
+        message->SetTObjectValueL<TMPXVideoDisplayCommand>
+                    ( KMPXMediaVideoDisplayCommand, EPbMsgVideoSurfaceChanged );
+    );
+
+    mDispHdlr->HandleVideoDisplayMessageL( message );
+
+    QVERIFY( ! mDispHdlr->iSurfaceId.IsNull() );
+
+    mDispHdlr->RemoveDisplayWindow();
+    cleanup();
+}
+
+void TestVideoDisplayHandler::testHandleVideoRemovedMessageL()
+{
+    setup();
+
+    CMPXMessage* message = NULL;
+    TRAP_IGNORE
+    (
+        message = CMPXMessage::NewL();
+        message->SetTObjectValueL<TMPXVideoDisplayCommand>
+                    ( KMPXMediaVideoDisplayCommand, EPbMsgVideoSurfaceRemoved );
+    );
+
+    mDispHdlr->HandleVideoDisplayMessageL( message );
+
+    QVERIFY( mDispHdlr->iSurfaceId.IsNull() );
+    QVERIFY( ! mDispHdlr->iViewWrapper->iAttatched );
+
+    mDispHdlr->RemoveDisplayWindow();
+    cleanup();
+}
+
+void TestVideoDisplayHandler::testSetAspectRatioL()
+{
+    setup();
+
+    int aspectRatio = mDispHdlr->SetAspectRatioL( EPbCmdNaturalAspectRatio );
+
+    QVERIFY( aspectRatio == EMMFNatural );
+
+    mDispHdlr->RemoveDisplayWindow();
+    cleanup();
+}
+
+void TestVideoDisplayHandler::testSetDefaultAspectRatioL()
+{
+    setup();
+
+    //
+    // get window size
+    //
+    RWindow *window = mBaseVideoView->getWindow();
+    TRect displayRect = TRect( TPoint( window->Position() ), TSize( window->Size() ) );
+
+    //
+    // get window aspect ratio
+    //   if device is in landscape mode, width > height
+    //   if device is in portrait mode, width < height
+    //
+    TReal32 width = (TReal32) displayRect.Width();
+    TReal32 height = (TReal32) displayRect.Height();
+    TReal32 displayAspectRatio = (width > height)? (width / height) : (height / width);
+
+    //
+    // aspect ratio zoom
+    //
+    mFileDetails = new VideoPlaybackViewFileDetails();
+    mFileDetails->mVideoHeight = 280;
+    mFileDetails->mVideoWidth  = 600;
+
+    int aspectRatio = mDispHdlr->SetDefaultAspectRatioL( mFileDetails, displayAspectRatio );
+
+    QVERIFY( aspectRatio == EMMFZoom );
+
+    //
+    // aspect ratio stretch
+    //
+    mFileDetails->mVideoHeight = 144;
+    mFileDetails->mVideoWidth  = 220;
+
+    aspectRatio = mDispHdlr->SetDefaultAspectRatioL( mFileDetails, displayAspectRatio );
+
+    QVERIFY( aspectRatio == EMMFStretch );
+
+    mDispHdlr->RemoveDisplayWindow();
+
+    cleanup();
+}
+
+void TestVideoDisplayHandler::testUpdateVideoRectL()
+{
+    setup();
+
+    RWindow *window = mBaseVideoView->getWindow();
+
+    TRect displayRect = TRect( 0, 0, 200, 300 );
+
+    mDispHdlr->UpdateVideoRectL( displayRect, false );
+
+    QCOMPARE( mDispHdlr->iWindowRect, displayRect);
+
+    mDispHdlr->RemoveDisplayWindow();
+    cleanup();
+}
+
+// End of file
+