• bcg
  • NEWBIE
  • 5 Points
  • Member since 2010

  • Chatter
    Feed
  • 0
    Best Answers
  • 0
    Likes Received
  • 0
    Likes Given
  • 12
    Questions
  • 26
    Replies

Hello Everyone,

 

am facing some problem in test method code, actually am new to this and don't knw much about test method,  code coverage is done by this test method is 59%, but probelm am facing is ,So pls anyone check the code and tell me where am doing wrong, its giving error of :

Insert failed. First exception on row 0; first error: REQUIRED_FIELD_MISSING, Required fields are missing: [Candidate_Name__c, Father_Name__c]: [Candidate_Name__c, Father_Name__c]
 

Please check the same if anyone knows....code of class is given below:

/*This apex class is used to save the Entrance Registration Data Entrance Registration Object, and Educational Information
of student. And educational information data is saving in Educational Information object.*/

//Apex Class
public class EntranceRegistrationCls{
 
    //Variable Declaration
    public String MasterId = '';
    public String EduRecordID;
    String TabURL;
    
    //Getter Setter Property Declaration
    public List<Educational_Information__c> EduList{get; set;}
    public Educational_Information__c Education{get;set;}
    
    //List Delcaration
    public list<Educational_Information__c> delList = new list<Educational_Information__c>();   
    public Entrance_Registration__c EntranceReg = new Entrance_Registration__c();
    public Entrance_Registration__c CurrentEntranceReg {get;set;}     
    ApexPages.StandardController controller;
    
    //constructor of EntranceRegistrationCls class
    public EntranceRegistrationCls(ApexPages.StandardController controller){        
        try{
            system.debug('yess');
            this.controller = controller;
            EntList = new List<Entrance_Registration__c>();
            EduList= new List<Educational_Information__c>();        
            EduList.add(new Educational_Information__c());
            Education= new Educational_Information__c();
            getMasterId();            
                if(MasterId == null || MasterId == ''){
                }else{
                    system.debug('Truee..>>'+MasterId);     
                    EntranceReg =[SELECT Id,Name FROM Entrance_Registration__c WHERE Id =:MasterId];
                    EduList=  [SELECT Id,Board_University__c,Degree_Diploma_Certificate_Etc_specify__c, Year_of_Passing__c,Education__c,Institute_College__c,Marks_CGPA__c,Mode_of_Education__c,
                               Status__c FROM Educational_Information__c WHERE Entrance_Master_Id__c =: EntranceReg.Id ];
                    system.debug('Yesssss--->>'+EduList);
                } 
        }
        catch(Exception ex){  
            ApexPages.Message myMsg = new ApexPages.Message(ApexPages.Severity.ERROR, ex.getMessage());
            ApexPages.addMessage(myMsg);
        }
    }
    //End of Constructor
    
    //Get Method for getting the current page id of Entrance Registration    
    public String getMasterId() {
        if(MasterId == null || MasterId == '')
            MasterId= ApexPages.CurrentPage().getParameters().get('ID');
            return MasterId;
    }
    //End of Get Method
    
    //Set Method for setting the value of Enratnce Registration    
    public void setMasterId(String val){
        MasterId = val;
    }
    //End of Set Method
    
    //To add any row method  
    public void addrow() {                              
        for(Integer i=0;i<EduList.size();i++){           
            EduList.add(new Educational_Information__c());                 
            return;
        }
    }
    //To remove any row method        
    public void removeRow(){  
        Integer i = EduList.size();
        if(EduList[i-1].Id <> null)
        delList.add(EduList[i-1]);
        EduList.remove(i-1); 
    }  
    // Save method to save whole data
    public PageReference save(){        
        Schema.DescribeSObjectResult SObjectResult = Schema.SObjectType.Entrance_Registration__c;
        String ObjectKey = SObjectResult.getKeyPrefix();
        TabURL = '/'+ ObjectKey +'/o';
        system.debug('Yes....>>'+TabURL);
            try{
                EntranceReg = (Entrance_Registration__c)controller.getRecord();
                CurrentEntranceReg = EntranceReg;
                system.debug('Yuuuupp>>>>'+CurrentEntranceReg);
                        
            }
            catch (Exception ex){
                ApexPages.Message errMsg = new ApexPages.Message(ApexPages.Severity.ERROR, ex.getMessage());
                ApexPages.addMessage(errMsg);
                return null;
            }
            try{
                if(CurrentEntranceReg.id <> null){
                        update CurrentEntranceReg;
                } else{
                        insert CurrentEntranceReg;
                  }
                  system.debug('Yes'+EduList);
                  
                for(Educational_Information__c ast: EduList){
                    if(ast.Id == null) 
                        ast.Entrance_Master_Id__c =  CurrentEntranceReg.ID;                        
                        ast.Education__c = ast.Education__c;
                        system.debug('Trueeeee...>'+ast.Entrance_Master_Id__c);
                        ast.Board_University__c = ast.Board_University__c;
                        ast.Institute_College__c = ast.Institute_College__c;
                        ast.Marks_CGPA__c = ast.Marks_CGPA__c;
                        ast.Mode_of_Education__c = ast.Mode_of_Education__c;
                        ast.Status__c = ast.Status__c;
                        ast.Year_of_Passing__c = ast.Year_of_Passing__c;
                        ast.Degree_Diploma_Certificate_Etc_specify__c=ast.Degree_Diploma_Certificate_Etc_specify__c;                    
                 }
                 system.debug('TRUE--->'+EduList);   
                upsert EduList;          
            }
            catch (Exception ex){
                ApexPages.Message errMsg = new ApexPages.Message(ApexPages.Severity.ERROR, ex.getMessage());
                ApexPages.addMessage(errMsg);
                return null;
            }            
            PageReference home = new PageReference(TabURL);        
            home.setRedirect(true);        
            return home;                                                
    }
    //End of Save Method
    static testMethod void testEntranceReg(){
        
        Test.startTest();
        PageReference PageRef = Page.EntranceRegistrationVf;
        test.setCurrentPage(PageRef);
        
       ApexPages.StandardController thecontroller = new ApexPages.StandardController(new Entrance_Registration__c());
       EntranceRegistrationCls controller = new EntranceRegistrationCls(thecontroller);
       controller.addrow();
       controller.removeRow();
        
        for(Entrance_Registration__c Ent:controller.CurrentEntranceReg){
            Ent.Candidate_Name__c ='Neeru';
            Ent.Father_Name__c ='Mr. Rakesh Nagpal';
        }
        controller.save();
        Test.stopTest();    
    }
        /*Entrance_Registration__c[] EntReg = new Entrance_Registration__c[]{
            new Entrance_Registration__c(
                Candidate_Name__c='Test Name',Father_Name__c='Test Father Name')};
         insert EntReg;
         
       ApexPages.StandardController thecontroller = new ApexPages.StandardController(new Entrance_Registration__c());
       EntranceRegistrationCls controller = new EntranceRegistrationCls(thecontroller);
       EntranceRegistrationCls  Ent =new EntranceRegistrationCls (thecontroller);
       Ent.save();
       Ent.addrow();
       Ent.removeRow(); */           
   
   /* static testMethod void myUnitTest() {
        PageReference PageRef = Page.EntranceRegistrationVf;
        test.setCurrentPage(PageRef); 
        Apexpages.Standardcontroller sc = new Apexpages.Standardcontroller(new Entrance_Registration__c());
        EntranceRegistrationCls controller = new EntranceRegistrationCls(sc);
        String MasterId;
        controller.setMasterId(MasterId);
        controller.addrow();
        controller.removeRow();
        controller.save();
    }*/
 
}
//End of Apex Class

 

when am saving this its giving error :

Compile Error: Loop must iterate over a collection type: SOBJECT:Entrance_Registration__c at line 140 column 42

Thanks In Advance

Hello Everyone,

 

Actually, am designing reports on visualforce page, not using Standard reports of salesforce. i want to implement button name Export to Excel. am not getting anything to implement the same. If anyone know the coding for export button pls post the code.

 

Pls help me for the same.

 

 

Thanks In Advance

 

Hello,

 

I have two screens one is for add room and other is for add floor. in add floor screen i have two input Fields i.e. Number of Floors and Series Start from. if i enter number of Floor= 5 and Series Start from= A then in other screen i.e. Add room Screen a picklist is created i.e. Floor in that options are like A1,A2,A3,A4,A5. these value are based on that two input fields. and the picklist is updated when a new records user create.

 

Please help me out how to do this if anyone having idea regarding this.

 

 

Thanks In Advance.

Hello Everyone,

 

 I am facing some problem in locking the records. pls anyone know how to solve this problem then tell me. i want when i save some records and that records are visible in related list, but after 24hrs that records are disable for end users. how it is possible.

 

 

Thanks In advance.

Hi all,

 

I'm new in Salesforce. I try to select multiple values, for example we select Users, from the lookup search button. It can only select one User in each field. If we want to get two Users in one field, how to use to lookup search? What and where should I make up configurations?

 

 

 

Thanks a lot.

Hi i have a canvas area where users draw their signatures, but how can i capture this as an attachment when saving?

I have a question regarding a "export data to excel" on a Visualforce page.

For example, I retrieve a bunch of records of a SObject on the extension class in a List ( like "List<Account>").
I want to create a button or a link on the visualforce page to export all the records inside that list to Excel.

Is that possible, does anybody knows how to do it ?

I have query results coming as following: for contact 1 for three questions and answers.

 

for Contact 1

 Q1  - ans1

 Q2 - ans2

  Q3 - ans3

 

for Contact 2

 Q1  - ans1

 Q2 - ans2

  Q3 - ans3

I want to dislay the above results as following:

       Q1    Q2    Q3

C1   ans1 ans2 ans3

C3   ans1 ans2 ans3

 can someone please help me create a class in my controller that help create this display in my apex page? How to display column values as row hearders..

 

I really appreciate any suggestions?

 

 

Hi All,

 

I'm developing application on force.com platform and I need to do the following:

 

1) upload image using Visualforce page

2) save uploaded image to the force.com database 

3) retrieve saved image from the database and display it on another Visualforce page 

 

For step 1 I can use <apex:inputFile ../> component to get an Apex blob object representing uploaded image.

However, for step 2 I don't know how to save this object to force.com database as it doesn't support blob fields.

For step 3 I assume I can use <apex:image .. /> component to display the image.

 

Could anyone advice if I'm on the right track or what is the right way to do this kind of things on Force.com platform?

 

Thanks in advance,

Dennis 

Hi,

 

I have a VF page in which i have Apex input text controls and a command Button control.

I am able to fill the Text boxes using the properties created in the controller.

 

My requirement here is when clicked on the command button in the Vf page i want to dynamically add a input text to the VF page.

 

Can we do it using Apex code??.

 

I have been looking around for adding controls in VF page using Apex code. I went through the developers guide and cook book for reference even then i failed to get the result.

 

Do any one have an idea about adding apex controls dynamically??

Please help me out...This might be a very silly question to ask but i am not able to resolve this problem from days.

 

Thanks in Advance,

pspl 

 

 

 

 

 

<script> function getValue () { var myString = 'Test Value'; return myString; } </script> <apex:pageBlockTable value="{!myData}" var="aMyData" id="MyData"> <apex:column headerValue="My Custom Value"> <!--getValue() is my supposed javascript function that will return me the value -> <apex:outputField value="{!$getValue ();}"/> </apex:column> </apex:pageBlockTable>

 

I want to get some value placed in the 'value' attribute of my apex:outputFiled/apex:inputFiled through a javascript. Is it possible?
Following is the code for what i want to do (this code will not work, just to explain what I want to do)

 

Regards,

Rao

 

 

Message Edited by Kamran-Rao on 06-30-2009 04:59 AM
I have created a custom object for Sales Aid & Sample Requests.  The purpose of this object is to enable the user to put in a request from either the Lead or the Contact for various sales aids or samples.  Once the request is completed, it will be emailed to the appropriate fulfillment person and copied to additional internal people.

Since a Sales Aid or Sample can be requested for either a Lead or a Contact, I would like to use the same object on both of these objects (Lead/Contact).  I have a Lookup field for Contact as well as a Lookup field for Lead.  My problems start when I want to use a formula field to bring in the Lead Address or Contact Address, depending upon whether the request is generated from a Lead or a Contact.  There are a few other fields that I would also like to use a formula to populate, but of course, these field names differ between the two.  Of course, I can create a "Lead Address field" and a "Contact Address field", etc., but this looks messy so I was looking for a way to (1) identify whether the request is being generated from a Lead or Contact (2) Pass by formula the correct values and (3) still be able to pull all of the fields into an email template, so even our personnel without Salesforce.com licenses can see that the sample/sales aid was requested.  I will also need to be able to pull together a single report of all of the sales aids/samples fulfilled. 

Does anyone have any suggestions or knowledge of how to identify what object the request was generated from, and then have the remaining formula fields reference and return the correct values?

Thanks for any insight as I've been mulling on this one for some time.
Hello everyone, just wanted to share with the community this custom component I made and give something back for the help I've received. :smileyhappy:

The purpose of the component is to enable autocomplete in lookup fields. I used the autocomplete js created by Jim Roos:
(http://www.jimroos.com/2007/05/ajax-autocomplete.html) but made some modifications to it so that it could interact with an Apex controller among some other things...

So my idea was that if you were making a VF page that had an inputfield that was related to a lookupfield you would just insert this autocomplete component to that inputfield. Something like this:

Code:
           <apex:inputField value="{!Contact.accountid}" id="accname" styleClass="cField">
<c:autocomplete ObjectName="Accounts" InputId="{!$Component.accname}" AutoCompleteId="accACid" ClassName="autocomplete300"/>
</apex:inputField>

The component has 4 parameters:

The name of the object or custom object that the inputfield relates to (new objects must be added inside the apex classes since i had some problems constructing a dynamic query).
The InputId which is used to relate the component to the input field
The id for the Component
A classname parameter that basically just defines the width of the suggestions menu.

Here's a screenshot of how it looks like in action:




Here's a link to the file containing the required files:

AutoCompleteComponent



Jonathan.


Message Edited by jonathan rico on 08-16-2008 01:55 PM

Message Edited by jonathan rico on 08-17-2008 09:04 AM
Message Edited by jonathan rico on 01-02-2010 05:01 PM