tcpiputils/dhcp/te_dhcp/src/te_dhcpserverteststep.cpp
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:33:58 +0100
branchRCL_3
changeset 22 8d540f55e491
parent 0 af10295192d8
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: 201035 Kit: 201035

// Copyright (c) 2006-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:
// Test cases to harness Symbian DHCP server
// 
//

/**
 @file te_dhcpserverteststep.cpp
*/
#include "te_dhcpserverteststep.h"
#include "../../include/DHCPStatesDebug.h"

#ifdef SYMBIAN_NETWORKING_DHCP_MSG_HEADERS
#include <networking/dhcpconfig.h>
#endif // SYMBIAN_NETWORKING_DHCP_MSG_HEADERS

#ifdef SYMBIAN_ENABLE_SPLIT_HEADERS
#include <nifman_internal.h>
#endif

TVerdict CDhcpTestStepServ_1::doTestStepL()
/**
* @return - EPass if successfully launches server, EFail otherwise
* Launches server on a custom port with Hardware address params set to serve any client
*/
	{
	SetTestStepResult(EFail);
	
	RSocketServ eSock;
	TInt err = eSock.Connect();
	TESTEL(err == KErrNone, err);
	CleanupClosePushL(eSock);
	
	RConnection connNET1;
	err = connNET1.Open(eSock);
	TESTEL(err == KErrNone, err);
	CleanupClosePushL(connNET1);

#ifdef _DEBUG
    User::LeaveIfError(RProperty::Set(KMyPropertyCat, KMyPropertyDestPortv4, 4836));
#endif
    
	err = connNET1.Start(iConnPrefs); // see test script for IAP used
	TESTEL(err == KErrNone, err);

	TRequestStatus status;

    const TInt KMacAddrLength = 6;
    TBuf8<KMacAddrLength> address;
    GetProvisioningMacL(ConfigSection(), _L("AnyMac"), address);
    connNET1.Ioctl(KCOLConfiguration, KConnDhcpSetHwAddressParams, status, &address);

  User::WaitForRequest(status);
  TESTEL(status == KErrNone, status.Int());
    
	INFO_PRINTF1(_L("DHCP server started.."));
	User::After(630 * 1000000);
	INFO_PRINTF1(_L("DHCP server STOPPED.."));
	

	err = connNET1.Stop();
	TESTEL(err == KErrNone, err);

	CleanupStack::PopAndDestroy(&connNET1);
	CleanupStack::PopAndDestroy(&eSock);
	
	SetTestStepResult(EPass);
	return TestStepResult();

	}

TVerdict CDhcpTestStepServ_2::doTestStepL()
/**
* @return - EPass if successfully launches server, EFail otherwise
* Launches server on a custom port with Hardware address params set 
* to serve one client with a particular MAC address and
* Lease time of the IP address set to 0
*/
	{
	SetTestStepResult(EFail);
	
	RSocketServ eSock;
	TInt err = eSock.Connect();
	TESTEL(err == KErrNone, err);
	CleanupClosePushL(eSock);
	
	RConnection connNET1;
	err = connNET1.Open(eSock);
	TESTEL(err == KErrNone, err);
	CleanupClosePushL(connNET1);

#ifdef _DEBUG
    User::LeaveIfError(RProperty::Set(KMyPropertyCat, KMyDefaultLeaseTime, 0));
    User::LeaveIfError(RProperty::Set(KMyPropertyCat, KMyPropertyDestPortv4, 4836));
#endif
    
	err = connNET1.Start(iConnPrefs); // see test script for IAP used
	TESTEL(err == KErrNone, err);

	TRequestStatus status;

    TBuf8<13> bufDes;
    bufDes.FillZ(13);
    TDhcp4RawOptionDataPckg pckg(bufDes);
    
    TUint opcode = 54; //OpCode Translates to EDHCPServerID for the server
    pckg.SetOpCode(opcode);
        
    const TUint dhcpOptName = KConnSetDhcpRawOptionData;    
    
    // Set raw option data either for ip4
    connNET1.Ioctl(KCOLConfiguration, dhcpOptName, status, &bufDes);

    User::WaitForRequest(status);
    TESTEL(status == KErrNone, status.Int());
    
    //Using MAC address of dhcp client that requests IP from this server (04215E312156)
    const TInt KMacAddrLength = 6;
    TBuf8<KMacAddrLength> address;
    GetProvisioningMacL(ConfigSection(), _L("ProvisionMac"), address);
    connNET1.Ioctl(KCOLConfiguration, KConnDhcpSetHwAddressParams, status, &address);

    User::WaitForRequest(status);
    TESTEL(status == KErrNone, status.Int());
    
	INFO_PRINTF1(_L("DHCP server started.."));
	User::After(650 * 1000000);
	INFO_PRINTF1(_L("DHCP server STOPPED.."));
	

	err = connNET1.Stop();
	TESTEL(err == KErrNone, err);

	CleanupStack::PopAndDestroy(&connNET1);
	CleanupStack::PopAndDestroy(&eSock);
	
	SetTestStepResult(EPass);
	return TestStepResult();

	}

TVerdict CDhcpTestStepServ_3::doTestStepL()
/**
* @return - EPass if successfully launches server, EFail otherwise
* Launches server on a custom port with Hardware address params set 
* to serve any client and lease time of the IP address set to a -ve value
*/
	{
	SetTestStepResult(EFail);
	
	RSocketServ eSock;
	TInt err = eSock.Connect();
	TESTEL(err == KErrNone, err);
	CleanupClosePushL(eSock);
	
	RConnection connNET1;
	err = connNET1.Open(eSock);
	TESTEL(err == KErrNone, err);
	CleanupClosePushL(connNET1);

#ifdef _DEBUG
    User::LeaveIfError(RProperty::Set(KMyPropertyCat, KMyDefaultLeaseTime, -20));
    User::LeaveIfError(RProperty::Set(KMyPropertyCat, KMyPropertyDestPortv4, 4836));
#endif
    
	err = connNET1.Start(iConnPrefs); // see test script for IAP used
	TESTEL(err == KErrNone, err);

	TRequestStatus status;

    TBuf8<13> bufDes;
    bufDes.FillZ(13);
    TDhcp4RawOptionDataPckg pckg(bufDes);
    
    TUint opcode = 54; //OpCode Translates to EDHCPServerID for the server
    pckg.SetOpCode(opcode);
        
    const TUint dhcpOptName = KConnSetDhcpRawOptionData;    
    
    // Set raw option data either for ip4
    connNET1.Ioctl(KCOLConfiguration, dhcpOptName, status, &bufDes);

    User::WaitForRequest(status);
    TESTEL(status == KErrNone, status.Int());
    
    const TInt KMacAddrLength = 6;
    TBuf8<KMacAddrLength> address;
    GetProvisioningMacL(ConfigSection(), _L("AnyMac"), address);
    connNET1.Ioctl(KCOLConfiguration, KConnDhcpSetHwAddressParams, status, &address);

    User::WaitForRequest(status);
    TESTEL(status == KErrNone, status.Int());
    
	INFO_PRINTF1(_L("DHCP server started.."));
	User::After(650 * 1000000);
	INFO_PRINTF1(_L("DHCP server STOPPED.."));
	

	err = connNET1.Stop();
	TESTEL(err == KErrNone, err);

	CleanupStack::PopAndDestroy(&connNET1);
	CleanupStack::PopAndDestroy(&eSock);
	
	SetTestStepResult(EPass);
	return TestStepResult();

	}

TVerdict CDhcpTestStepServ_4::doTestStepL()
/**
* @return - EPass if successfully launches server, EFail otherwise
* Launches server on a custom port with Hardware address params set 
* to serve any client initially, then using provisioning RESET to clear
* the provisioning set earlier and set the provisioning to a single client
*/
    {
    SetTestStepResult(EFail);
    
    RSocketServ eSock;
    TInt err = eSock.Connect();
    TESTEL(err == KErrNone, err);
    CleanupClosePushL(eSock);
    
    RConnection connNET1;
    err = connNET1.Open(eSock);
    TESTEL(err == KErrNone, err);
    CleanupClosePushL(connNET1);

#ifdef _DEBUG
    User::LeaveIfError(RProperty::Set(KMyPropertyCat, KMyPropertyDestPortv4, 4836));
#endif
    
    err = connNET1.Start(iConnPrefs); // see test script for IAP used
    TESTEL(err == KErrNone, err);

    TRequestStatus status;

    const TInt KMacAddrLength = 6;
    TBuf8<KMacAddrLength> address;
    GetProvisioningMacL(ConfigSection(), _L("AnyMac"), address);
    connNET1.Ioctl(KCOLConfiguration, KConnDhcpSetHwAddressParams, status, &address);

    User::WaitForRequest(status);
    TESTEL(status == KErrNone, status.Int());
    
    INFO_PRINTF1(_L("DHCP server started.."));
    User::After(300 * 1000000);
    
    TBuf8<KMacAddrLength> address1;
    GetProvisioningMacL(ConfigSection(), _L("ResetMac"), address1);
    connNET1.Ioctl(KCOLConfiguration, KConnDhcpSetHwAddressParams, status, &address1);

    User::WaitForRequest(status);
    TESTEL(status == KErrNone, status.Int());
    
    INFO_PRINTF1(_L("DHCP server Provisioning Reset.."));
    
    User::After(50 * 1000000);
    
    TBuf8<KMacAddrLength> address2;
    GetProvisioningMacL(ConfigSection(), _L("InvalidMac1"), address2);
    connNET1.Ioctl(KCOLConfiguration, KConnDhcpSetHwAddressParams, status, &address2);

    User::WaitForRequest(status);
    TESTEL(status == KErrNone, status.Int());
    INFO_PRINTF1(_L("DHCP server Provisioning Set.."));
    User::After(300 * 1000000);
    INFO_PRINTF1(_L("DHCP server STOPPED.."));
    

    err = connNET1.Stop();
    TESTEL(err == KErrNone, err);

    CleanupStack::PopAndDestroy(&connNET1);
    CleanupStack::PopAndDestroy(&eSock);
    
    SetTestStepResult(EPass);
    return TestStepResult();

    }

TVerdict CDhcpTestStepServ_5::doTestStepL()
/**
* @return - Negetive testing. Expected to return EFail
* Launches server on a custom port with Hardware address params set 
* to serve one client with hw address length beyond the standard length
*/
    {
    SetTestStepResult(EFail);
    
    RSocketServ eSock;
    TInt err = eSock.Connect();
    TESTEL(err == KErrNone, err);
    CleanupClosePushL(eSock);
    
    RConnection connNET1;
    err = connNET1.Open(eSock);
    TESTEL(err == KErrNone, err);
    CleanupClosePushL(connNET1);

#ifdef _DEBUG
     User::LeaveIfError(RProperty::Set(KMyPropertyCat, KMyPropertyDestPortv4, 4836));
#endif
    
    err = connNET1.Start(iConnPrefs); // see test script for IAP used
    TESTEL(err == KErrNone, err);

    TRequestStatus status;

    const TInt KMacAddrLength = 7;
    TBuf8<KMacAddrLength> address;
    GetProvisioningMacL(ConfigSection(), _L("InvalidMac2"), address);
	connNET1.Ioctl(KCOLConfiguration, KConnDhcpSetHwAddressParams, status, &address);
	
    User::WaitForRequest(status);

    if (status != KErrNone)
    	{
    	SetTestStepError(status.Int());
    	}
    else
    	{
	    INFO_PRINTF1(_L("DHCP server started.."));
	    User::After(40 * 1000000);
	    INFO_PRINTF1(_L("DHCP server STOPPED.."));
	    
	
	    err = connNET1.Stop();
	    TESTEL(err == KErrNone, err);
	
	  	}
    CleanupStack::PopAndDestroy(&connNET1);
    CleanupStack::PopAndDestroy(&eSock);

    SetTestStepResult(EPass);
    return TestStepResult();

    }

TVerdict CDhcpTestStepServ_6::doTestStepL()
/**
* @return - EPass if successfully launches server, EFail otherwise
* Launches client on a custom port where the DHCP server is expected
* to lease out IP with -ve lease time
*/
	{
	SetTestStepResult(EFail);	
	
	RSocketServ eSock;
	TInt err = eSock.Connect();
	TESTEL(err == KErrNone, err);
	CleanupClosePushL(eSock);
#ifdef _DEBUG
	User::LeaveIfError(RProperty::Set(KMyPropertyCat, KMyPropertyDestPortv4, 4836));
	User::LeaveIfError(RProperty::Set(KMyPropertyCat, KMyPropertyDestPortv6, 547));
#endif		
	
	RConnection connNET1;
	err = connNET1.Open(eSock);
	TESTEL(err == KErrNone, err);
	CleanupClosePushL(connNET1);
	
	TRequestStatus stat1;
	connNET1.Start(iConnPrefs,stat1);// see test script for IAP used
	
	err = connNET1.Stop();
	TESTEL(err == KErrNone, err);

	CleanupStack::PopAndDestroy(&connNET1); 
	CleanupStack::PopAndDestroy(&eSock); 
	
	SetTestStepResult(EPass);
	return TestStepResult();
	}