mmsharing/mmshengine/tsrc/ut_engine/src/ut_muspropertywatch.cpp
branchRCL_3
changeset 22 73a1feb507fb
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mmsharing/mmshengine/tsrc/ut_engine/src/ut_muspropertywatch.cpp	Tue Aug 31 15:12:07 2010 +0300
@@ -0,0 +1,268 @@
+/*
+* 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:
+*
+*/
+
+
+//  INTERNAL INCLUDES
+#include "ut_muspropertywatch.h"
+#include "muspropertywatch.h"
+
+#include "mussessionproperties.h"
+
+//  SYSTEM INCLUDES
+#include <eunitmacros.h>
+#include <e32property.h>
+
+using namespace NMusSessionApi;
+
+const TInt KMusUiTestKey = 1100;
+const TInt KMusUiTestPropertyReadInteger = 200;
+_LIT( KMusUiTestPropertyReadDesc, "testread" ); 
+TUid KMusUiDummyUid = { 1000 }; // Unit testing dummy
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+UT_CMusPropertyWatch* UT_CMusPropertyWatch::NewL()
+    {
+    UT_CMusPropertyWatch* self = UT_CMusPropertyWatch::NewLC();
+    CleanupStack::Pop( self );
+    return self;
+    }
+
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+UT_CMusPropertyWatch* UT_CMusPropertyWatch::NewLC()
+    {
+    UT_CMusPropertyWatch* self = new( ELeave ) UT_CMusPropertyWatch();
+    CleanupStack::PushL( self );
+    self->ConstructL();
+    return self;
+    }
+
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+UT_CMusPropertyWatch::~UT_CMusPropertyWatch()
+    {
+    // NOP
+    }
+
+
+// -----------------------------------------------------------------------------
+// Default constructor
+// -----------------------------------------------------------------------------
+//
+UT_CMusPropertyWatch::UT_CMusPropertyWatch()
+    {
+    // NOP
+    }
+
+
+// -----------------------------------------------------------------------------
+// Second phase construct
+// -----------------------------------------------------------------------------
+//
+void UT_CMusPropertyWatch::ConstructL()
+    {
+    // The ConstructL from the base class CEUnitTestSuiteClass must be called.
+    // It generates the test case table.
+    CEUnitTestSuiteClass::ConstructL();
+    }
+
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+void UT_CMusPropertyWatch::SetupL()
+    {
+    PropertyHelper::SetErrorCode( KErrNone );
+    RProperty::Set( KMusUiDummyUid, KMusUiTestKey, KMusUiTestPropertyReadInteger );
+    iPropertyWatch = CMusPropertyWatch::NewL( iPropertyObserver,
+                                                KMusUiDummyUid,
+                                                KMusUiTestKey );
+    }
+
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+void UT_CMusPropertyWatch::Teardown()
+    {
+    delete iPropertyWatch;
+    PropertyHelper::Close();
+    }
+
+
+
+// TEST CASES
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+void UT_CMusPropertyWatch::UT_CMusPropertyWatch_ReadIntPropertyLL()
+    {
+
+    // Teesting leave
+    PropertyHelper::SetErrorCode( KErrNotFound );
+    RProperty::Set( KMusUiDummyUid, KMusUiTestKey, KMusUiTestPropertyReadInteger );
+    TInt value;
+    TRAPD( err, value = CMusPropertyWatch::ReadIntPropertyL( KMusUiTestKey ) );
+    EUNIT_ASSERT( err == KErrNotFound );
+
+    // Testing return value
+    PropertyHelper::SetErrorCode( KErrNone );
+    RProperty::Set( KMusUiDummyUid, KMusUiTestKey, KMusUiTestPropertyReadInteger );
+    EUNIT_ASSERT(  CMusPropertyWatch::ReadIntPropertyL( KMusUiTestKey ) ==
+                   KMusUiTestPropertyReadInteger );
+
+    }
+
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+void UT_CMusPropertyWatch::UT_CMusPropertyWatch_ReadDescPropertyLL()
+    {
+    // Teesting leave
+    PropertyHelper::SetErrorCode( KErrNotFound );
+    TRAPD( err,  CMusPropertyWatch::ReadDescPropertyL( KMusUiTestKey ) );
+    EUNIT_ASSERT( err == KErrNotFound );
+
+    // Testing return value
+    RProperty::Set( KMusUiDummyUid, KMusUiTestKey, KMusUiTestPropertyReadDesc );
+    PropertyHelper::SetErrorCode( KErrNone );
+    HBufC* result = CMusPropertyWatch::ReadDescPropertyL( KMusUiTestKey );
+    CleanupStack::PushL( result );
+    EUNIT_ASSERT(  KMusUiTestPropertyReadDesc().Compare( result->Des() ) == 0 );
+    CleanupStack::PopAndDestroy( result );
+    }
+
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+void UT_CMusPropertyWatch::UT_CMusPropertyWatch_DoCancelL()
+    {
+    PropertyHelper::SetErrorCode( KErrNone );
+    iPropertyWatch->Cancel();
+    EUNIT_ASSERT( PropertyHelper::GetCalledFunction() == RProperty::ECancel );
+    }
+
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+void UT_CMusPropertyWatch::UT_CMusPropertyWatch_RunLL()
+    {
+
+    // Leave test
+    PropertyHelper::SetErrorCode( KErrNotFound );
+    iPropertyWatch->Cancel();
+    TRAPD( err, iPropertyWatch->RunL() );
+    EUNIT_ASSERT( err == KErrNotFound );
+
+
+    // SessionPropertyChanged
+    PropertyHelper::SetErrorCode( KErrNone );
+    iPropertyWatch->Cancel();
+    iPropertyWatch->RunL();
+    EUNIT_ASSERT( iPropertyObserver.iCalledFunction ==
+                  TMusPropertyObserverStub::EPropertyChanged );
+
+    }
+
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+void UT_CMusPropertyWatch::UT_CMusPropertyWatch_RunErrorL()
+    {
+
+    // Allways returns KErrNone
+    PropertyHelper::SetErrorCode( KErrNone );
+    EUNIT_ASSERT( iPropertyWatch->RunError( KErrNotFound ) == KErrNone );
+
+    // is right observer called
+    PropertyHelper::SetErrorCode( KErrNone );
+    EUNIT_ASSERT( iPropertyObserver.iCalledFunction ==
+                  TMusPropertyObserverStub::EHandlePropertyError );
+    }
+
+
+
+//  TEST TABLE
+
+EUNIT_BEGIN_TEST_TABLE(
+    UT_CMusPropertyWatch,
+    "UT_CMusPropertyWatch",
+    "UNIT" )
+
+EUNIT_TEST(
+    "ReadIntPropertyLL - test ",
+    "CMusPropertyWatch",
+    "ReadIntPropertyLL",
+    "FUNCTIONALITY",
+    SetupL, UT_CMusPropertyWatch_ReadIntPropertyLL, Teardown)
+
+EUNIT_TEST(
+    "ReadDescPropertyLL - test ",
+    "CMusPropertyWatch",
+    "ReadDescPropertyLL",
+    "FUNCTIONALITY",
+    SetupL, UT_CMusPropertyWatch_ReadDescPropertyLL, Teardown)
+
+EUNIT_TEST(
+    "DoCancelL - test ",
+    "CMusPropertyWatch",
+    "DoCancelL",
+    "FUNCTIONALITY",
+    SetupL, UT_CMusPropertyWatch_DoCancelL, Teardown)
+
+EUNIT_TEST(
+    "RunLL - test ",
+    "CMusPropertyWatch",
+    "RunLL",
+    "FUNCTIONALITY",
+    SetupL, UT_CMusPropertyWatch_RunLL, Teardown)
+
+EUNIT_TEST(
+    "RunErrorL - test ",
+    "CMusPropertyWatch",
+    "RunErrorL",
+    "FUNCTIONALITY",
+    SetupL, UT_CMusPropertyWatch_RunErrorL, Teardown)
+
+
+EUNIT_END_TEST_TABLE
+
+
+//  END OF FILE
+
+