mmlibs/mmfw/tsrc/mmfintegrationtest/vclntavi/src/testexternaldisplay.cpp
author hgs
Mon, 18 Oct 2010 12:47:26 +0100
changeset 4 9d4397b300d1
permissions -rw-r--r--
2010wk44_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
4
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
     1
// Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
     2
// All rights reserved.
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
     7
//
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
     8
// Initial Contributors:
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    10
//
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    11
// Contributors:
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    12
//
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    13
// Description:
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    14
//
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    15
 
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    16
#include "testvideoplayer2.h"
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    17
#include <bautils.h>
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    18
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    19
// file names used to control plugin through their existence. If any are new files are added make sure
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    20
// they are also added to TidyFiles().
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    21
_LIT(KInitExtDisplayHDMI, "c:\\vclntavi\\InitExtDisplayHDMI.txt");
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    22
_LIT(KInitExtDisplayAnalog, "c:\\vclntavi\\InitExtDisplayAnalog.txt");
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    23
_LIT(KConnectExtDisplayOverHDMI, "c:\\vclntavi\\ConnectExtDisplayOverHDMI.txt");
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    24
_LIT(KConnectExtDisplayOverAnalog, "c:\\vclntavi\\ConnectExtDisplayOverAnalog.txt");
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    25
_LIT(KDisconnectExtDisplay, "c:\\vclntavi\\DisconnectExtDisplay.txt");
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    26
void TidyFiles()
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    27
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    28
    RFs fs;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    29
    TInt error= fs.Connect();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    30
    if(error == KErrNone)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    31
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    32
        if(BaflUtils::FileExists(fs, KInitExtDisplayHDMI))
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    33
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    34
            fs.Delete(KInitExtDisplayHDMI);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    35
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    36
        if(BaflUtils::FileExists(fs, KInitExtDisplayAnalog))
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    37
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    38
            fs.Delete(KInitExtDisplayAnalog);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    39
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    40
        if(BaflUtils::FileExists(fs, KConnectExtDisplayOverHDMI))
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    41
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    42
            fs.Delete(KConnectExtDisplayOverHDMI);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    43
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    44
        if(BaflUtils::FileExists(fs, KConnectExtDisplayOverAnalog))
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    45
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    46
            fs.Delete(KConnectExtDisplayOverAnalog);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    47
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    48
        if(BaflUtils::FileExists(fs, KDisconnectExtDisplay))
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    49
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    50
            fs.Delete(KDisconnectExtDisplay);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    51
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    52
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    53
}
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    54
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    55
_LIT(KFilename, "filename");
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    56
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    57
//
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    58
// RTestMediaClientExternalDisplay
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    59
//
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    60
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    61
/**
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    62
 * RTestMediaClientExternalDisplay::Constructor
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    63
 */
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    64
RTestMediaClientExternalDisplay::RTestMediaClientExternalDisplay(const TDesC& aTestName)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    65
    : RTestVclnt2AviPlayerStep(aTestName, aTestName, KFilename, KErrNone)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    66
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    67
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    68
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    69
/**
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    70
 * RTestMediaClientExternalDisplay::NewL
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    71
 */
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    72
RTestMediaClientExternalDisplay* RTestMediaClientExternalDisplay::NewL(const TDesC& aTestName)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    73
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    74
    RTestMediaClientExternalDisplay* self = new (ELeave) RTestMediaClientExternalDisplay(aTestName);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    75
    return self;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    76
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    77
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    78
/**
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    79
 * RTestMediaClientExternalDisplay::DoTestStepPreambleL
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    80
 */
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    81
TVerdict RTestMediaClientExternalDisplay::DoTestStepPreambleL()
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    82
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    83
    TidyFiles();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    84
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    85
    TVerdict verdict = SetInitialConnectionType();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    86
    if(verdict != EPass)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    87
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    88
        return verdict;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    89
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    90
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    91
    verdict = SetConnectionTypeNotification();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    92
    if(verdict != EPass)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    93
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    94
        return verdict;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    95
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    96
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    97
    verdict = SetExternalDisplayControl();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    98
    if(verdict != EPass)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
    99
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   100
        return verdict;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   101
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   102
    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   103
    return RTestVclnt2AviPlayerStep::DoTestStepPreambleL();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   104
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   105
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   106
TVerdict RTestMediaClientExternalDisplay::SetInitialConnectionType()
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   107
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   108
    // Create a file as named in ini file. When external display test plugin is constructed it
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   109
    // checks to see what filenames exist and sets inital connection type as appropriate.
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   110
    // If string does not exist in ini file then plugin initialises with exetrnal display disconnected.
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   111
    if(GetStringFromConfig(iSectName, _L("initialExternalDisplayType"), iInitialExternalDisplayTypeFilename))
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   112
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   113
        if(iInitialExternalDisplayTypeFilename.Compare(KInitExtDisplayHDMI) == 0)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   114
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   115
            INFO_PRINTF2(_L("Creating %S"), &iInitialExternalDisplayTypeFilename);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   116
            INFO_PRINTF1(_L("External HDMI Display initially connected"));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   117
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   118
        else if(iInitialExternalDisplayTypeFilename.Compare(KInitExtDisplayAnalog) == 0)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   119
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   120
            INFO_PRINTF2(_L("Creating %S"), &iInitialExternalDisplayTypeFilename);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   121
            INFO_PRINTF1(_L("External Analog Display initially connected"));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   122
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   123
        else
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   124
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   125
            INFO_PRINTF2(_L("External display setting unkown, %S"), &iInitialExternalDisplayTypeFilename);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   126
            return EInconclusive;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   127
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   128
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   129
        // connect to file system and open file
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   130
        RFs fs;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   131
        if(fs.Connect() != KErrNone)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   132
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   133
            return EInconclusive;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   134
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   135
        RFile file;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   136
        if(file.Replace(fs, iInitialExternalDisplayTypeFilename, EFileWrite) != KErrNone)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   137
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   138
            fs.Close();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   139
            return EInconclusive;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   140
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   141
        
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   142
        file.Close();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   143
        fs.Close();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   144
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   145
    else
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   146
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   147
        INFO_PRINTF1(_L("External Display initially disconnected!"));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   148
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   149
    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   150
    return EPass;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   151
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   152
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   153
TVerdict RTestMediaClientExternalDisplay::SetConnectionTypeNotification()
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   154
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   155
    // Now create file for the next connection type. This is used to emit a connect or disocnnect notification
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   156
    // after a few seconds. Note that if the initial and next connection types are the same the external
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   157
    // display test plugin will not emit a notification.    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   158
    if(GetStringFromConfig(iSectName, _L("nextExternalDisplayType"), iNextExternalDisplayTypeFilename))
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   159
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   160
        if(iNextExternalDisplayTypeFilename.Compare(KConnectExtDisplayOverHDMI) == 0)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   161
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   162
            INFO_PRINTF2(_L("Creating %S"), &iNextExternalDisplayTypeFilename);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   163
            INFO_PRINTF1(_L("External HDMI Display to be connected and notification emitted"));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   164
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   165
        else if(iNextExternalDisplayTypeFilename.Compare(KConnectExtDisplayOverAnalog) == 0)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   166
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   167
            INFO_PRINTF2(_L("Creating %S"), &iNextExternalDisplayTypeFilename);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   168
            INFO_PRINTF1(_L("External Analog Display to be connected and notification emitted"));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   169
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   170
        else if(iNextExternalDisplayTypeFilename.Compare(KDisconnectExtDisplay) == 0)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   171
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   172
            INFO_PRINTF2(_L("Creating %S"), &iNextExternalDisplayTypeFilename);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   173
            INFO_PRINTF1(_L("External Display to be disconnected and notification emitted"));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   174
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   175
        else
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   176
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   177
            INFO_PRINTF2(_L("External display switch setting unkown, %S"), &iNextExternalDisplayTypeFilename);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   178
            return EInconclusive;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   179
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   180
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   181
        // connect to file system and open file
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   182
        RFs fs;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   183
        if(fs.Connect() != KErrNone)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   184
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   185
            return EInconclusive;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   186
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   187
        RFile file;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   188
        if(file.Replace(fs, iNextExternalDisplayTypeFilename, EFileWrite) != KErrNone)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   189
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   190
            fs.Close();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   191
            return EInconclusive;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   192
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   193
        
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   194
        file.Close();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   195
        fs.Close();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   196
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   197
    else
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   198
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   199
        INFO_PRINTF1(_L("No External Display switching requested!"));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   200
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   201
    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   202
    return EPass;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   203
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   204
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   205
TVerdict RTestMediaClientExternalDisplay::SetExternalDisplayControl()
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   206
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   207
    if(GetBoolFromConfig(iSectName, _L("externalDisplayControl"), iExternalDisplayControl))
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   208
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   209
        INFO_PRINTF2(_L("External display switch control set to %d"), iExternalDisplayControl);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   210
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   211
    else
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   212
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   213
        return EInconclusive;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   214
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   215
    return EPass;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   216
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   217
    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   218
/**
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   219
 * RTestMediaClientExternalDisplay::DoTestStepPostambleL
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   220
 */
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   221
TVerdict RTestMediaClientExternalDisplay::DoTestStepPostambleL()
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   222
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   223
    RFs fs;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   224
    // connect to file system and open file
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   225
    User::LeaveIfError(fs.Connect());
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   226
    CleanupClosePushL(fs);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   227
    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   228
    if((iInitialExternalDisplayTypeFilename.Length()!= 0) && BaflUtils::FileExists(fs, iInitialExternalDisplayTypeFilename))
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   229
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   230
        User::LeaveIfError(fs.Delete(iInitialExternalDisplayTypeFilename));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   231
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   232
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   233
    if((iNextExternalDisplayTypeFilename.Length()!= 0) && BaflUtils::FileExists(fs, iNextExternalDisplayTypeFilename))
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   234
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   235
        User::LeaveIfError(fs.Delete(iNextExternalDisplayTypeFilename));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   236
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   237
    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   238
    CleanupStack::PopAndDestroy(1); //fs
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   239
    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   240
    return RTestVclnt2AviPlayerStep::DoTestStepPostambleL();        
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   241
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   242
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   243
/**
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   244
 * RTestMediaClientExternalDisplay::FsmL
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   245
 */
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   246
void RTestMediaClientExternalDisplay::FsmL(TVclntTestPlayEvents aEventCode)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   247
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   248
    if (FsmCheck(aEventCode))
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   249
        {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   250
        switch (aEventCode)
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   251
            {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   252
            case EVPIdle:
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   253
                HandleIdleL();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   254
                break;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   255
                
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   256
            case EVPOpenComplete:
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   257
                HandleOpenCompleteL();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   258
                break;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   259
                
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   260
            case EVPPrepareComplete:                    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   261
                HandlePrepareCompleteL();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   262
                break;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   263
                
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   264
            case EVPPlayComplete:
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   265
                HandlePlayCompleteL();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   266
                break;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   267
            }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   268
        }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   269
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   270
    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   271
void RTestMediaClientExternalDisplay::HandleIdleL()
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   272
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   273
    // Open iVideoPlayer
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   274
    INFO_PRINTF2(_L("iVideoPlayer2->OpenFileL() %S"), &iFilename);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   275
    iVideoPlayer2->OpenFileL(iFilename, KMmfTestAviPlayControllerUid);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   276
    PrepareState(EVPOpenComplete, KErrNone);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   277
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   278
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   279
void RTestMediaClientExternalDisplay::HandleOpenCompleteL()
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   280
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   281
    // Prepare iVideoPlayer2
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   282
    INFO_PRINTF1(_L("iVideoPlayer2->Prepare()"));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   283
    iVideoPlayer2->Prepare();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   284
    PrepareState(EVPPrepareComplete, KErrNone);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   285
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   286
    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   287
void RTestMediaClientExternalDisplay::HandlePrepareCompleteL()
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   288
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   289
    // Add display window using default values - ie. video extent & window clipping 
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   290
    // defaulted to whole window
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   291
    INFO_PRINTF1(_L("iVideoPlayer2->AddDisplayWindowL()"));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   292
    iVideoPlayer2->AddDisplayWindowL(iWs, *iScreen, *iWindow);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   293
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   294
    // set external display control
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   295
    iVideoPlayer2->SetExternalDisplaySwitchingL((*iScreen).GetScreenNumber(), iExternalDisplayControl);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   296
    
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   297
    // trigger the video to start playing                
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   298
    StartPlayback();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   299
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   300
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   301
void RTestMediaClientExternalDisplay::HandlePlayCompleteL()
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   302
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   303
    iTestStepResult = EPass;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   304
    CActiveScheduler::Stop();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   305
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   306
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   307
void RTestMediaClientExternalDisplay::StartPlayback()
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   308
    {
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   309
    iError = KErrTimedOut;
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   310
    INFO_PRINTF1(_L("iVideoPlayer2->Play()"));
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   311
    PrepareState(EVPPlayComplete, KErrNone);
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   312
    iVideoPlayer2->Play();
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   313
    }
9d4397b300d1 2010wk44_01
hgs
parents:
diff changeset
   314