videoplayback/hbvideoplaybackview/tsrc/testmpxvideoplaybackfiledetailswidget/src/testmpxvideoplaybackfiledetailswidget.cpp
changeset 44 518105d52e45
parent 42 17f382c040b1
child 49 824471cb468a
--- a/videoplayback/hbvideoplaybackview/tsrc/testmpxvideoplaybackfiledetailswidget/src/testmpxvideoplaybackfiledetailswidget.cpp	Fri Jul 02 17:14:33 2010 +0300
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,611 +0,0 @@
-/**
-* Copyright (c) 2010 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 TestMPXVideoPlaybackFileDetailsWidget
-* 
-*/
-
-// Version : %version:  4 %
-
-
-#include <QDateTime>
-#include <QFileInfo>
-
-#include <hbmainwindow.h>
-#include <hbapplication.h>
-#include <hblistwidget.h>
-#include <hblistwidgetitem.h>
-#include <hbextendedlocale.h>
-
-#include "mpxvideoplaybackviewfiledetails.h"
-#include "mpxvideoplaybackcontrolscontroller.h"
-#include "testmpxvideoplaybackfiledetailswidget.h"
-
-#define private public
-#include "mpxvideoplaybackfiledetailswidget.h"
-#undef private
-
-const QString KFILEPATH = "C:\\sample1.wav";
-
-
-// ---------------------------------------------------------------------------
-// main
-// ---------------------------------------------------------------------------
-//
-int main(int argc, char *argv[])
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::Main()"));
-
-    HbApplication app(argc, argv);
-    HbMainWindow window;
-
-    TestMPXVideoPlaybackFileDetailsWidget tv;
-
-    char *pass[3];
-    pass[0] = argv[0];
-    pass[1] = "-o";
-    pass[2] = "c:\\data\\testmpxvideoplaybackfiledetailswidget.txt";
-    
-    int res = QTest::qExec(&tv, 3, pass);
-    
-    return res;
-}
-
-
-// ---------------------------------------------------------------------------
-// init
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::init()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::init()"));
-
-    mController = new QMPXVideoPlaybackControlsController();   
-    mWidget = new QMPXVideoPlaybackFileDetailsWidget( mController );
-}
-
-// ---------------------------------------------------------------------------
-// cleanup
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::cleanup()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::cleanup()"));
-
-    if ( mController )
-    {
-        delete mController;
-        mController = NULL;
-    }
-
-    if ( mWidget )
-    {
-        delete mWidget;
-        mWidget = NULL;
-    }
-}
-
-// ---------------------------------------------------------------------------
-// testTitle
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testTitle()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testTitle()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-
-    //
-    // For Audio only view
-    //
-    mController->mViewMode = EAudioOnlyView;
-
-    // If title information is available
-    details->mTitle = "Title for Test clip";
-    mWidget->updateWithFileDetails( details );
-    verifyResult( "Title", true, details->mTitle );
-
-    mWidget->mListWidget->clear();
-    mWidget->mFileDetailsUpdated = false;
-
-    // If title informatio is not available
-    details->mTitle = "";
-    details->mClipName = KFILEPATH;
-
-    mWidget->updateWithFileDetails( details );
-    verifyResult( "Title", true, "sample1" );
-
-    mWidget->mListWidget->clear();
-    mWidget->mFileDetailsUpdated = false;
-
-    //
-    // For Details view
-    //
-    mController->mViewMode = EFullScreenView;
-
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Title", false );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testDescription
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testDescription()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testDescription()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-    details->mDescription = "This is for unit test";
-    
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Description", true, details->mDescription );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testDate
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testDuration()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testDuration()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-
-    //
-    // If it's local mode, need to show the duration
-    //
-    details->mPlaybackMode = EMPXVideoLocal;
-    details->mDuration = 3700000;
-    
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Duration", true, "1 hr 1 min 40 sec" );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testDate
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testDate()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testDate()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-    
-    QDateTime dateTime;
-    QString created("");
-    QString modified("");
-    details->mClipName = KFILEPATH;
-    QFileInfo fileInfo( details->mClipName ); 
-    
-    //
-    // If it is streaming case, we don't show size information
-    //    
-    details->mPlaybackMode = EMPXVideoStreaming;
-    mWidget->updateWithFileDetails( details );
-
-    //
-    // verify results for streaming clip
-    //
-    verifyResult( "Date", false );
-    verifyResult( "Modified", false );
-
-    //
-    // clear the widget list
-    //
-    mWidget->mListWidget->clear();
-    mWidget->mFileDetailsUpdated = false;
-
-    //
-    // local clip, with no date/time metadata
-    //
-    details->mPlaybackMode = EMPXVideoLocal;
-    mWidget->updateWithFileDetails( details );
-
-    //
-    // compare and verify 'Date' for non-metadata local clip
-    //
-    dateTime = fileInfo.created();
-    created = dateTimeStringFormat( dateTime );
-    verifyResult( "Date", true, created, true );
-    
-    //
-    // compare and verify 'Modified' for non-metadata local clip
-    //
-    dateTime = fileInfo.lastModified();
-    modified = dateTimeStringFormat( dateTime );
-    verifyResult( "Modified", true, modified, true );
-    
-    //
-    // clear the widget list
-    //
-    mWidget->mListWidget->clear();
-    mWidget->mFileDetailsUpdated = false;
-    
-    //
-    // local clip, with date/time metadata 
-    //
-    details->mPlaybackMode = EMPXVideoLocal;
-    details->mCreationTime = 1242367251;        // POSIX creation time
-    details->mModificationTime = 1270773249;    // POSIX modification time    
-    mWidget->updateWithFileDetails( details );
-
-    //
-    // compare and verify 'Date' for metadata local clip
-    //
-    dateTime.setTime_t( details->mCreationTime );
-    created = dateTimeStringFormat( dateTime );
-    verifyResult( "Date", true, created, true );
-    
-    //
-    // compare and verify 'Modified' for metadata local clip
-    //
-    dateTime.setTime_t( details->mModificationTime ); 
-    modified = dateTimeStringFormat( dateTime );
-    verifyResult( "Modified", true, modified, true );
-
-    //
-    // clean up
-    //
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testLocation
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testLocation()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testLocation()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-    details->mLocation = "C:\\data\\Videos\\";
-    
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Location", true, details->mLocation );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testAuthor
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testAuthor()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testAuthor()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-    details->mArtist = "Fusion";
-    
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Author", true, details->mArtist );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testCopyright
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testCopyright()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testCopyright()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-    details->mCopyright = "Fusion team";
-    
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Copyright", true, details->mCopyright );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testLanguage
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testLanguage()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testLanguage()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-    details->mLanguage = "English";
-    
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Language", true, details->mLanguage );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testKeywords
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testKeywords()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testKeywords()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-    details->mKeywords = "QTest";
-    
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Keywords", true, details->mKeywords );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testSize
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testSize()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testSize()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-
-    //
-    // If it is streaming case, we don't show size information
-    //
-    details->mPlaybackMode = EMPXVideoStreaming;
-    details->mClipName = KFILEPATH;
-
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Size", false );
-
-    mWidget->mListWidget->clear();
-    mWidget->mFileDetailsUpdated = false;
-
-    //
-    // If it is local, we show size information
-    //
-    details->mPlaybackMode = EMPXVideoLocal;
-    mWidget->updateWithFileDetails( details );
-    
-    verifyResult( "Size", true, "", false );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testResolution
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testResolution()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testResolution()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-
-    //
-    // If it is audio only clip, don't need to show resolution
-    //
-    details->mVideoEnabled = false;
-    
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Resolution", false );
-
-    mWidget->mListWidget->clear();
-    mWidget->mFileDetailsUpdated = false;
-
-    //
-    // If it has video track
-    //
-    details->mVideoEnabled = true;
-    details->mVideoWidth = 640;
-    details->mVideoHeight = 360;
-
-    mWidget->updateWithFileDetails( details );
-
-    QString resolution = QString("%1x%2")
-            .arg( details->mVideoWidth ).arg( details->mVideoHeight );
-
-    verifyResult( "Resolution", true, resolution );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testFormat
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testFormat()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testFormat()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-    details->mMimeType = "Nothing";
-    
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Format", true, details->mMimeType );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testBitrate
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testBitrate()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testBitrate()"));
-
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-    details->mBitRate = 512;
-    
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Bitrate", true, "512 kbps" );
-
-    cleanup();
-}
-
-// ---------------------------------------------------------------------------
-// testFolder
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::testFolder()
-{
-    MPX_ENTER_EXIT(_L("TestMPXVideoPlaybackFileDetailsWidget::testFolder()"));
-
-    init();
-
-    QMPXVideoPlaybackViewFileDetails *details = mController->fileDetails();
-
-    //
-    // If it is streaming case, we don't show folder information
-    //
-    details->mPlaybackMode = EMPXVideoStreaming;
-    details->mClipName = KFILEPATH;
-    
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Collection", false );
-
-    mWidget->mListWidget->clear();
-    mWidget->mFileDetailsUpdated = false;
-
-    //
-    // If it is local case, we show folder information
-    //
-    details->mPlaybackMode = EMPXVideoLocal;
-
-    mWidget->updateWithFileDetails( details );
-
-    verifyResult( "Collection", false );
-
-    cleanup();
-
-}
-
-// ---------------------------------------------------------------------------
-// verifyResult
-// ---------------------------------------------------------------------------
-//
-void TestMPXVideoPlaybackFileDetailsWidget::verifyResult( 
-        QString primaryText, bool exist, QString expectedSecondaryText, bool needToBeCompared )
-{
-    MPX_DEBUG(_L("TestMPXVideoPlaybackFileDetailsWidget::verifyResult(%s, %d, %s, %d)"),
-            primaryText.data(), exist, expectedSecondaryText.data(), needToBeCompared );
-    
-    QString secondaryText = "";
-    int i = 0;
-
-    for( ; i < mWidget->mListWidget->count() ; i++ )
-    {
-        HbListWidgetItem *item = mWidget->mListWidget->item( i );
-
-        if ( item->text() == primaryText )
-        {
-            secondaryText = item->secondaryText();
-            break;
-        }
-    }
-
-    //
-    // If the item needs to be existed in HbListWidget, check the result
-    //
-    if ( exist )
-    {
-        if ( needToBeCompared )
-        {
-            MPX_DEBUG(_L("TestMPXVideoPlaybackFileDetailsWidget::verifyResult() : secondaryText(%s)"),
-                    secondaryText.data() );
-            
-            QVERIFY( expectedSecondaryText == secondaryText );
-        }
-        else
-        {
-            MPX_DEBUG(_L("TestMPXVideoPlaybackFileDetailsWidget::verifyResult() : i(%d) count(%d)"),
-                    i, mWidget->mListWidget->count() );
-            
-            //
-            // Doens't need to compare the secondary text. Just make sure it's in the list
-            //
-            QVERIFY( i < mWidget->mListWidget->count() );
-        }
-
-    }
-    //
-    // If not, just make sure that item is not in the list
-    //
-    else
-    {
-        QVERIFY( i == mWidget->mListWidget->count() );
-    }
-}
-
-
-// -------------------------------------------------------------------------------------------------
-// dateTimeStringFormat
-// -------------------------------------------------------------------------------------------------
-//
-QString TestMPXVideoPlaybackFileDetailsWidget::dateTimeStringFormat( QDateTime dateTime )
-{
-    HbExtendedLocale locale = HbExtendedLocale::system();
-    QString date = locale.format( dateTime.date(), r_qtn_date_usual );
-    QString time = locale.format( dateTime.time(), r_qtn_time_long_with_zero );
-    QString dateTimeString( date + "  " + time );
-    
-    MPX_DEBUG(_L("TestMPXVideoPlaybackFileDetailsWidget::dateTimeStringFormat() ret '%s'"),
-            dateTimeString.data() );
-    
-    return dateTimeString;    
-}
-
-// End of file