os/security/crypto/weakcryptospi/test/tcryptospi/src/dummyecccipherloadstep.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
/*
sl@0
     2
* Copyright (c) 2009-2010 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     3
* All rights reserved.
sl@0
     4
* This component and the accompanying materials are made available
sl@0
     5
* under the terms of the License "Eclipse Public License v1.0"
sl@0
     6
* which accompanies this distribution, and is available
sl@0
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     8
*
sl@0
     9
* Initial Contributors:
sl@0
    10
* Nokia Corporation - initial contribution.
sl@0
    11
*
sl@0
    12
* Contributors:
sl@0
    13
*
sl@0
    14
* Description: 
sl@0
    15
* Example CTestStep derived implementation
sl@0
    16
*
sl@0
    17
*/
sl@0
    18
sl@0
    19
sl@0
    20
/**
sl@0
    21
 @file
sl@0
    22
 @internalTechnology
sl@0
    23
*/
sl@0
    24
#include "dummyecccipherloadstep.h"
sl@0
    25
sl@0
    26
#include <cryptospi/cryptoasymmetriccipherapi.h>
sl@0
    27
#include <cryptospi/cryptokeypairgeneratorapi.h>
sl@0
    28
#include <cryptospi/keypair.h>
sl@0
    29
#include "filereader.h"
sl@0
    30
sl@0
    31
using namespace CryptoSpi;
sl@0
    32
sl@0
    33
CDummyEccCipherLoadStep::~CDummyEccCipherLoadStep()
sl@0
    34
	{
sl@0
    35
	}
sl@0
    36
sl@0
    37
sl@0
    38
CDummyEccCipherLoadStep::CDummyEccCipherLoadStep()
sl@0
    39
	{
sl@0
    40
	SetTestStepName(KDummyEccCipherLoadStep);
sl@0
    41
	}
sl@0
    42
sl@0
    43
sl@0
    44
TVerdict CDummyEccCipherLoadStep::doTestStepPreambleL()
sl@0
    45
	{
sl@0
    46
	SetTestStepResult(EPass);
sl@0
    47
	return TestStepResult();
sl@0
    48
	}
sl@0
    49
sl@0
    50
sl@0
    51
TVerdict CDummyEccCipherLoadStep::doTestStepL()
sl@0
    52
	{
sl@0
    53
sl@0
    54
	INFO_PRINTF1(_L("*** Dummy Ecc Cipher - Load ***"));
sl@0
    55
	INFO_PRINTF2(_L("HEAP CELLS: %d"), User::CountAllocCells());
sl@0
    56
	
sl@0
    57
    //Assume failure, unless all is successful
sl@0
    58
    SetTestStepResult(EFail);
sl@0
    59
    
sl@0
    60
    TVariantPtrC algorithm;
sl@0
    61
    TVariantPtrC paddingMode;
sl@0
    62
    
sl@0
    63
    if(!GetStringFromConfig(ConfigSection(),KConfigAlgorithmUid, algorithm) || 
sl@0
    64
        !GetStringFromConfig(ConfigSection(),KConfigPaddingMode, paddingMode ))
sl@0
    65
        {
sl@0
    66
        ERR_PRINTF1(_L("*** FAIL: Algorithm id or padding mode is missing ***"));
sl@0
    67
        User::Leave(KErrNotFound);
sl@0
    68
        }
sl@0
    69
    INFO_PRINTF1(_L("Generating dummy ECC keys"));
sl@0
    70
          
sl@0
    71
    /**
sl@0
    72
     * Note that we are actually generating RSA keys in place 
sl@0
    73
     * of ECC keys here. The reason for that is we do not have 
sl@0
    74
     * a working ECC implementation. This test case just tests 
sl@0
    75
     * if dummyecc cipher is getting loaded. This is being 
sl@0
    76
     * tested since algorithm is set to KAlgorithmCipherEcc. 
sl@0
    77
     * Keys have no significance in this test case.
sl@0
    78
     */
sl@0
    79
    CCryptoParams* keyParams = CCryptoParams::NewLC(); 
sl@0
    80
    keyParams->AddL(KKeyExponent, KRsaKeyParameterEUid);
sl@0
    81
    keyParams->AddL(KRsaPrivateKeyStandard, KRsaKeyTypeUid);
sl@0
    82
sl@0
    83
    //Create Key Pair Generator Objects
sl@0
    84
    CKeyPairGenerator * keypairImpl = NULL;
sl@0
    85
            
sl@0
    86
    // create a key pair generator implementation interface
sl@0
    87
    TRAPD_LOG(err,CKeyPairGeneratorFactory::CreateKeyPairGeneratorL(
sl@0
    88
                                    keypairImpl, 
sl@0
    89
                                    KRSAKeyPairGeneratorUid, 
sl@0
    90
                                    keyParams));
sl@0
    91
    if(err != KErrNone)
sl@0
    92
        {
sl@0
    93
        ERR_PRINTF1(_L("*** FAIL: Failed to Create generator impl interface ***"));
sl@0
    94
        CleanupStack::PopAndDestroy(keyParams);
sl@0
    95
        return EFail;
sl@0
    96
        }
sl@0
    97
    CleanupStack::PushL(keypairImpl);
sl@0
    98
sl@0
    99
    // Create a Key Pair
sl@0
   100
    CKeyPair* keyPair = NULL;
sl@0
   101
    TRAP_LOG(err,keypairImpl->GenerateKeyPairL(1024, *keyParams, keyPair));
sl@0
   102
    if(err != KErrNone)
sl@0
   103
        {
sl@0
   104
        ERR_PRINTF1(_L("*** FAIL: Failed to Create key pair ***"));
sl@0
   105
        CleanupStack::PopAndDestroy(keypairImpl);
sl@0
   106
        CleanupStack::PopAndDestroy(keyParams);
sl@0
   107
        return EFail;
sl@0
   108
        }
sl@0
   109
    CleanupStack::PushL(keyPair);
sl@0
   110
    
sl@0
   111
    //*****************************************************
sl@0
   112
sl@0
   113
    INFO_PRINTF1(_L("Creating Dummy ECC Cipher Object..."));
sl@0
   114
    
sl@0
   115
    CryptoSpi::CAsymmetricCipher * impl = NULL;
sl@0
   116
        
sl@0
   117
    TRAP(err,CAsymmetricCipherFactory::CreateAsymmetricCipherL
sl@0
   118
                                        (
sl@0
   119
                                        impl,
sl@0
   120
                                        algorithm,
sl@0
   121
                                        keyPair->PrivateKey(),
sl@0
   122
                                        KCryptoModeDecryptUid,
sl@0
   123
                                        paddingMode,
sl@0
   124
                                        NULL));
sl@0
   125
sl@0
   126
    if(err == KErrNone)
sl@0
   127
        {
sl@0
   128
        delete impl;
sl@0
   129
        INFO_PRINTF1(_L("*** Dummy Ecc Cipher - Load: PASS ***"));
sl@0
   130
        SetTestStepResult(EPass);
sl@0
   131
        }
sl@0
   132
    else
sl@0
   133
        {
sl@0
   134
        ERR_PRINTF2(_L("*** FAIL: Failed to Create dummy Ecc Cipher Object - %d ***"), err);
sl@0
   135
        }
sl@0
   136
sl@0
   137
    CleanupStack::PopAndDestroy(keyPair);
sl@0
   138
    CleanupStack::PopAndDestroy(keypairImpl);			
sl@0
   139
    CleanupStack::PopAndDestroy(keyParams);
sl@0
   140
		
sl@0
   141
	INFO_PRINTF2(_L("HEAP CELLS: %d"), User::CountAllocCells());
sl@0
   142
sl@0
   143
	return TestStepResult();
sl@0
   144
	}
sl@0
   145
sl@0
   146
sl@0
   147
sl@0
   148
TVerdict CDummyEccCipherLoadStep::doTestStepPostambleL()
sl@0
   149
	{
sl@0
   150
	return TestStepResult();
sl@0
   151
	}