Tuesday, 13 November 2018

Controller update

/*
    Name               : AutomatedTestSetup_Controller
    Test class         : AutomatedTestSetup_Controller_Test
    Description        : For Automated Test class execution process(SP-684-Automate Test Classes execution in Salesforce Orgs)
    Created By         : Krishna yerru
    Created Date       : 23-Oct-2018

********************************************************************************************************************************
    Change Version   Name              Date                    Task/Case#                 Description
********************************************************************************************************************************

********************************************************************************************************************************     
*/


public with sharing class AutomatedTestSetup_Controller {

    public boolean hasScheduledJobs { get; set; }
    public boolean hasAbort { get; set; }
    public boolean hasemailpending { get; set; }
    public boolean isRunning { get; set; }
    public boolean isEmailing { get; set; } 
    public AutomatedTestSetup_Controller ATS { get; set; }
    public String DtValue {get; set; }
    public boolean showMessage {get;set;}
    public String showdatetime{get;set;}
    public String Staticstics{get;set;}
    public Decimal Percentage{get;set;}
    public String shddatetime {get;set;}
    public String ATRdetails {get;set;}
    public String PastATRdetails {get;set;}
    public List<CronTrigger> Schdjobs{get;set;}
    public String Jobstatus  {get;set;}
    public Automated_Test_Run__c AtrRecord  {get; set;}
    public Boolean isChecked { get; set; }
    public Boolean isCheckedRec { get; set; }
    public Boolean isAdhocChecked { get; set; }
    public Boolean isHomeChecked { get; set; }
    public Boolean reccurenceMsg;
    //recurrence related
    public boolean hasRecScheduledJobs { get; set; }   
     id ATERecordTypeId = Schema.SObjectType.Automated_Test_Run__c.getRecordTypeInfosByName().get('Automated Test Execution').getRecordTypeId();
     id ATEmailRecordTypeId = Schema.SObjectType.Automated_Test_Run__c.getRecordTypeInfosByName().get('Automated Test Email Notification').getRecordTypeId();
     //MultipleAdhocJobs
    public string SelectedAdhocJobId { get; set; }

    public PageReference doInsert() {
       List<Automated_Test_Run__c> ATSrecrdsinsert=New List<Automated_Test_Run__c>();
        String ADrandomnumberis=generateRandomNumber();
        String ADScheduleNameis='AdhocAutoTestRunner_'+AtrRecord.Query__c +'_'+ADrandomnumberis;
        AtrRecord.Query__c=AtrRecord.Query__c;
        AtrRecord.Excluded_Classes__c=AtrRecord.Excluded_Classes__c;
        AtrRecord.Exclude_Managed_Packages__c=AtrRecord.Exclude_Managed_Packages__c;
        AtrRecord.Schedule__c=AtrRecord.Schedule__c;
        AtrRecord.Schedule_Name__c= ADScheduleNameis;
     
        AtrRecord.RecordTypeId=ATERecordTypeId;
        ATSrecrdsinsert.add(AtrRecord);
     
        Automated_Test_Run__c ATEemail = new Automated_Test_Run__c();
        ATEemail.Query__c=AtrRecord.Query__c;
        ATEemail.Emails__c=AtrRecord.Emails__c;
        ATEemail.Email_on_Pass__c=AtrRecord.Email_on_Pass__c;
        ATEemail.Schedule_Name__c= ADScheduleNameis;
        ATEemail.RecordTypeId=ATEmailRecordTypeId;
        ATSrecrdsinsert.add(ATEemail);
        Savepoint sp = Database.setSavepoint();
        try{     
            scheduleJobs(AtrRecord.Schedule__c,ADScheduleNameis);
                if(showMessage==false){
                    upsert ATSrecrdsinsert;               
                }     
        }
        catch(exception ex){
            Database.rollback(sp);
        }
        GetATSRunDeatils();
        PageReference pageRef = new PageReference('/apex/AutomatedTestSetup');
       pageRef.setRedirect(true);
      return pageRef;
       
       
            //return null;
    }
    public Automated_Test_Run__c getAtrRecord()
    {
        return AtrRecord;
    }
 
 
    public AutomatedTestSetup_Controller(ApexPages.StandardController controller) {       
        AtrRecord = (Automated_Test_Run__c)Controller.getRecord();
        this.ATS=ATS;     
        showMessage=false;
        refreshHasScheduledJobs();     
        ShowAbortbutton();
        getPieData();
        Calculatepercentage();
        GetATSRunDeatils();
        EmailSendPending();
        //recurrence related
        System.debug('isCheckedRec value is1 '+isCheckedRec);
        //isCheckedRec=false;
        System.debug('isCheckedRec value is12is '+isCheckedRec); 
            if(isChecked==null){
             isCheckedRec = false;
             System.debug('isCheckedRec is ' +isCheckedRec);
         } 
        if(isAdhocChecked==null){
             isAdhocChecked = false;
             System.debug('isAdhocChecked is ' +isAdhocChecked);
         }   
        if(isHomeChecked==null){
             isHomeChecked = false;
             System.debug('isHomeChecked is ' +isHomeChecked);
         }     
        refreshHasRecrnsScheduledJobs();
    }   

    public void refreshHasScheduledJobs() {     
        integer jobCount = [SELECT count() FROM CronTrigger  where CronJobDetail.Name like '%AdhocAutoTestRunner%'];
        Schdjobs=[SELECT CronJobDetail.Name,CreatedDate,TimesTriggered,NextFireTime,State FROM CronTrigger where CronJobDetail.Name like '%AutoTestRunner%' and State in('WAITING','ACQUIRED','EXECUTING')];
        if(Schdjobs.size()>0){
            Jobstatus=Schdjobs[0].State;
            if(Schdjobs[0].NextFireTime!=null ){
            Datetime shddatetimeGSt=Schdjobs[0].NextFireTime;
            Datetime gmt = shddatetimeGSt;
             String timeZone = UserInfo.getTimeZone().getID();
             Datetime GivenDateTime=shddatetimeGSt;// here you can user your dates e.g. createddate
              Datetime localdt=Datetime.valueOf(GivenDateTime);
              //showdatetime = string.valueOfGmt(local);
              shddatetime=localdt.format();
              }
              else if(Jobstatus!=null && Jobstatus!='') {
                  shddatetime='Test Scheduled Job Current State is '+Jobstatus;
              }
            }           
        hasScheduledJobs = jobCount !=0;         
    }
    public void GetATSRunDeatils() {
        List<String> Keywords=New List<String>();
        Keywords.clear();
        ATRdetails='';
        for(Automated_Test_Run__c atr: [select Query__c, Excluded_Classes__c,
                            Email_on_Pass__c, Exclude_Managed_Packages__c
                            from Automated_Test_Run__c
                            //where Active__c = true and RecordTypeId=:ATERecordTypeId order by createdDate DESC limit 1]){
                            where RecordTypeId=:ATERecordTypeId order by createdDate DESC limit 1]){
                        Keywords.add(atr.Query__c);                   
        }
        if(Keywords.size()>0){
            for(String kw:Keywords){
            ATRdetails+=kw;
            }
        }
    }

    public void ShowAbortbutton(){
        integer runCount = [select count() from Automated_Test_Run__c limit 1];
        List<Test_Runner_Job__c> RunningJobnm =[Select Name,Automated_Test_Run__c,CreatedDate From Test_Runner_Job__c order by CreatedDate desc limit 1];
        if(RunningJobnm.size()>0){
            integer TestexecrunCount = [select count() from ApexTestQueueItem WHERE Status IN ('Holding','Queued','Preparing','Processing') and ParentJobId=:RunningJobnm[0].Name];
            hasAbort = TestexecrunCount > 0; 
         }     
    }
 
    public void EmailSendPending(){
        List<Test_Runner_Job__c> runCountJob = [select id from Test_Runner_Job__c where Processed__c=false order by CreatedDate desc limit 1];
        hasemailpending = runCountJob.size()> 0;                 
    }

    public string getTestRunLink() {
        return '/' + Automated_Test_Run__c.SObjectType.getDescribe().getKeyPrefix();
    }
    public PageReference getHomeLink() {
        PageReference pageRef = new PageReference('/apex/AutomatedTestSetup');
                    pageRef.setRedirect(true);
                    return pageRef;
    }

    public AutomatedTestSetup_Controller() {
         Automated_Test_Run__c AtrRecord = new Automated_Test_Run__c();
         refreshHasScheduledJobs();
         Calculatepercentage();
         ShowAbortbutton();
         EmailSendPending();
        System.debug('isCheckedRec value is1 '+isCheckedRec);
        //isCheckedRec=false;
        System.debug('isCheckedRec value is12is '+isCheckedRec);
        //click(); 
         if(isChecked==null){
             isCheckedRec = false;
             System.debug('isCheckedRec is ' +isCheckedRec);
         }
         if(isAdhocChecked==null){
             isAdhocChecked = false;
             System.debug('isAdhocChecked is ' +isAdhocChecked);
         }
         if(isHomeChecked==null){
             isHomeChecked = false;
             System.debug('isHomeChecked is ' +isHomeChecked);
         }
    }
 
    public PageReference scheduleJobs(Datetime DtValue,String ADScheduleNameis) {
     
        System.debug('Date & Time is given***1'+DtValue);
        deleteCompletedJobs();
        Datetime gmt = DtValue;
        String timeZone = UserInfo.getTimeZone().getID();
        Datetime GivenDateTime=DtValue;// here you can user your dates e.g. createddate
         System.debug('GivenDateTime is***'+GivenDateTime);       
                Datetime local=Datetime.valueOf(GivenDateTime);
                System.debug('local is***'+local);
                Map <Integer,String> monthNumbers = new Map <Integer,String> {1=>'Jan', 2=>'Feb',3=>'Mar',4=>'Apr', 5=>'May', 6=>'Jun',7=>'Jul',8=>'Aug', 9=>'Sep', 10=>'Oct', 11=>'Nov', 12=>'Dec'};
                String TestShdmonth=monthNumbers.get(local.month());
                String strSchedule = '0 ' + local.minute() + ' ' +local.hour()+ ' ' + local.day()+ ' ' + TestShdmonth+ ' ? ' + ' ' + local.year();
                System.debug('***strSchedule***'+strSchedule);
                AutoTestRunner.setup(strSchedule,ADScheduleNameis);
                refreshHasScheduledJobs();           
                GetATSRunDeatils();
               
               
     
    return null;
    }

    public PageReference CancelJobs() {   
          //List<CronTrigger> jobsToAbort = [select id,Name from CronJobDetail where Name like 'AutoTestRunner%' and JobType = '7'];
          List<CronTrigger> jobsToAbort = [select Id from CronTrigger where CronJobDetail.JobType = '7' and CronJobDetail.Name like '%AdhocAutoTestRunner%'];
              if(jobsToAbort.size()>0){
                  for (CronTrigger job : jobsToAbort) {
                   System.abortJob(job.Id);
                   }
               }
               PageReference pageRef = new PageReference('/apex/AutomatedTestSetup');
                    pageRef.setRedirect(true);
                    return pageRef;
    }
 
    public PageReference AbortTestJobs() { 
        Test_Runner_Job__c RunningJobnm =[Select Name,Automated_Test_Run__c,CreatedDate From Test_Runner_Job__c order by CreatedDate desc limit 1];
        ApexTestQueueItem[] items = [SELECT Id FROM ApexTestQueueItem WHERE Status IN ('Holding','Queued','Preparing','Processing') and ParentJobId=:RunningJobnm.Name];
        if(items.size()>0){
                for(ApexTestQueueItem item: items) {
                    item.Status = 'Aborted';
                }
                update items;
           }
         email();
        PageReference pageRef = new PageReference('/apex/AutomatedTestSetup');
        pageRef.setRedirect(true);
        return pageRef;
    }
 
    public void deleteCompletedJobs(){
        List<CronTrigger> jobsToAbort = [select Id,State from CronTrigger where CronJobDetail.JobType = '7' and CronJobDetail.Name like '%TestRunner%' and State='DELETED'];
              for (CronTrigger job : jobsToAbort) {
               System.abortJob(job.Id);
               }     
    }

    public void email() {
        emailUnprocessedJobStatus();
        isEmailing = true;
        ApexPages.addMessage(new ApexPages.Message(ApexPages.Severity.Confirm, 'Results processed and emailed'));
    }
 
    public static list<Messaging.SingleEmailMessage> emailUnprocessedJobStatus() {
          list<Test_Runner_Job__c> jobs = getUnprocessedJobs();     
          list<Messaging.SingleEmailMessage> messages =emailMethodStatus(jobs);   
              for (Test_Runner_Job__c job : jobs) {
                  job.Processed__c = true;
              }   
          update jobs; 
         return messages;
    }
 
   public static list<Test_Runner_Job__c> getUnprocessedJobs() {
        return [Select t.Name,
          t.Automated_Test_Run__r.Emails__c,
          t.Automated_Test_Run__r.Email_on_Pass__c,
          t.Automated_Test_Run__r.Name,
          t.Automated_Test_Run__c
          From Test_Runner_Job__c t where Processed__c = false];
   }

//Statistics part

    public Void Calculatepercentage() {
  PastATRdetails='';
        List<Test_Runner_Job__c> RunningJob =[Select Name,Automated_Test_Run__c,CreatedDate From Test_Runner_Job__c order by CreatedDate desc limit 1];
        if(RunningJob.size()>0){
   Automated_Test_Run__c PastATR=[select id,Query__c from Automated_Test_Run__c where id=:RunningJob[0].Automated_Test_Run__c order by createdDate DESC limit 1];
            PastATRdetails=PastATR.Query__c;
   integer TotalJobsis   =  [select count() FROM ApexTestQueueItem where ParentJobId=:RunningJob[0].Name];
            integer CompltedJobsis   =  [select count() FROM ApexTestQueueItem where Status IN ('Completed','Aborted') and ParentJobId=:RunningJob[0].Name];
                if((TotalJobsis>0)&& (CompltedJobsis>0)){
                Percentage=(CompltedJobsis*100)/TotalJobsis;
                System.debug('Total Jobs is'+TotalJobsis+ 'CompltedJobs' +CompltedJobsis+ 'Percentage is'+Percentage);
            }         
        }     
    }
    public List<PieWedgeData> getPieData() {
        List<PieWedgeData> data = new List<PieWedgeData>(); 
        List<Test_Runner_Job__c> RunningJob =[Select Name,Automated_Test_Run__c,CreatedDate From Test_Runner_Job__c order by CreatedDate desc limit 1];
              if(RunningJob.size()>0){
                  //integer Cmpltd       = [select count() FROM ApexTestResult WHERE Outcome = 'Pass' and AsyncApexJobId=:RunningJob[0].Name];
                  integer CmpltdPass       = [select count() FROM ApexTestResult WHERE Outcome = 'Pass' and AsyncApexJobId=:RunningJob[0].Name];
                  integer Failed       = [select count() FROM ApexTestResult WHERE Outcome = 'Fail' and AsyncApexJobId=:RunningJob[0].Name];
                  integer Queuedjobs   = [select count() FROM ApexTestQueueItem where Status='Queued' and ParentJobId=:RunningJob[0].Name];
                  integer TotalJobs   =  [select count() FROM ApexTestQueueItem where ParentJobId=:RunningJob[0].Name];
               
                        if(Queuedjobs>0){
                        data.add(new PieWedgeData('In Progress'+' '+Queuedjobs, +Queuedjobs));
                        }if(CmpltdPass>0){
                        data.add(new PieWedgeData('Passed'+' '+CmpltdPass, +CmpltdPass));
                        }if(Failed>0){
                        data.add(new PieWedgeData('Fail'+' '+Failed, +Failed));
                        }
               }
        return data;
    }
    // Wrapper class
    public class PieWedgeData {
       public String name { get; set; }
       public Integer data { get; set; }
       public Integer CmpltdPass{ get; set; }
       public Integer Failed{ get; set; }
       public Integer Queuedjobs{ get; set; }
           public PieWedgeData(String name, Integer data) {
                this.name = name;
                this.data = data;
            }
    }
 
    public PageReference Refresh(){
        deleteCompletedJobs();
        Calculatepercentage();
        refreshHasScheduledJobs();
        if(Percentage==100){
                email();                 
            }else{
                hasScheduledJobs = true;
            }                     
        PageReference pageRef = new PageReference('/apex/AutomatedTestSetup');
        pageRef.setRedirect(true);
        return pageRef;
    }
    //Scheduling Job run & Email Sending from Auotestrunner class
    // Enqueue all unit test classes as spec'd by Automated_Test_Run__c record(s)
 
    public static list<ID> enqueueTests() {
       
        List<CronTrigger> CurrentShedulejob = [select Id,State,CronJobDetail.Name from CronTrigger where CronJobDetail.JobType = '7' and CronJobDetail.Name like '%AdhocAutoTestRunner%' limit 1];
        System.debug('Cuurent Shedule Job Name '+CurrentShedulejob[0].CronJobDetail.Name+'Cuurent Shedule Job State is'+CurrentShedulejob[0].State);
        list<Id> jobIds = new list<Id>();
String JobNameis=CurrentShedulejob[0].CronJobDetail.Name;
        Id ATERecordTypeId = Schema.SObjectType.Automated_Test_Run__c.getRecordTypeInfosByName().get('Automated Test Execution').getRecordTypeId();
        Id ATEmilRecordTypeId = Schema.SObjectType.Automated_Test_Run__c.getRecordTypeInfosByName().get('Automated Test Email Notification').getRecordTypeId();
        Automated_Test_Run__c EmailRecord=[select Emails__c,Schedule_Name__c from Automated_Test_Run__c where RecordTypeId=:ATEmilRecordTypeId and Schedule_Name__c=:JobNameis  order by createdDate DESC limit 1];
        string whereExcluded = '';
        string Keywordis = '';
        string ATRIDis = '';
        for (Automated_Test_Run__c run : [select Query__c,Schedule_Name__c,Excluded_Classes__c,
            Email_on_Pass__c, Exclude_Managed_Packages__c
            from Automated_Test_Run__c where Active__c = true and RecordTypeId=:ATERecordTypeId and Schedule_Name__c=:EmailRecord.Schedule_Name__c order by createdDate DESC limit 1]) {
               ATRIDis=run.id;
                if (run.Excluded_Classes__c != null) {
                    for (string c : run.Excluded_Classes__c.split('[,\\s]+')) {
                        whereExcluded += 'and Name != \'' + c + '\'';
                    }
                }
                if (run.Exclude_Managed_Packages__c == True) {
                   whereExcluded += ' AND NameSpacePrefix = null';
                }
                if (run.Query__c != null && run.Query__c != ' ' ) {
                   Keywordis +=run.Query__c;
                }
           }
            string query = 'SELECT Id FROM ApexClass WHERE Name LIKE \'' + Keywordis+ '\' ' + whereExcluded;
            ApexClass[] testClasses = Database.query(query);
             
            if (testClasses.size() > 0) {
                ApexTestQueueItem[] queueItems = new List<ApexTestQueueItem>();
                for (ApexClass cls : testClasses) {
                    queueItems.add(new ApexTestQueueItem(ApexClassId=cls.Id));
                }
                if (!Test.isRunningTest()) {
                    DataBase.insert(queueItems,false);     
                    // Get the job ID of the first queue item returned.     
                    ApexTestQueueItem item =[SELECT ParentJobId FROM ApexTestQueueItem WHERE Id=:queueItems[0].Id LIMIT 1];                   
                    insert new Test_Runner_Job__c(Name = item.parentjobid, Automated_Test_Run__c = EmailRecord.Id);
                    jobIds.add(item.parentjobid);
                if(ATRIDis!='' && ATRIDis!=null){
                        Automated_Test_Run__c runATRrecd =[select id,Active__c from Automated_Test_Run__c where Id=:ATRIDis limit 1];
                           runATRrecd.Active__c = false;
                           update runATRrecd;
                   }
                 
                }
            }           
        return jobIds;
    }

    public static list<Messaging.SingleEmailMessage> emailMethodStatus(list<Test_Runner_Job__c> jobs) {
        set<string> jobNames = new set<string>();
        for (Test_Runner_Job__c job : jobs) {
            jobNames.add(job.Name);
        }   
        ApexTestResult[] results = [SELECT AsyncApexJobId, Outcome, ApexClass.Name, MethodName, Message, StackTrace
                                    FROM ApexTestResult
                                    WHERE AsyncApexJobId in :jobNames];
         
        return emailMethodStatus(jobs, results);
    }
     
    public static list<Messaging.SingleEmailMessage> emailMethodStatus(list<Test_Runner_Job__c> jobs, ApexTestResult[] results) {
        list<Messaging.SingleEmailMessage> messages = new list<Messaging.SingleEmailMessage>();
     
        for (Test_Runner_Job__c job : jobs) {
            system.debug('Test Runner Job: Id ' + job.Id + ' Name ' + job.Name);
            integer passed = 0;
            integer total = 0;
         
            string failTable = '<table border="1" cellpadding="5px">';
            string className = '';
             
            for (ApexTestResult atr : results) {
                system.debug('Apex Test Result: Id '  + atr.AsyncApexJobId);
                if ((string)atr.AsyncApexJobId == job.Name || (Test.isRunningTest() && jobs.size() == 1)) {
                    if (atr.Outcome == 'Pass') {
                        passed++;
                    } else {
                        if (atr.ApexClass.Name != className) {
                            className = atr.ApexClass.Name;
                            failTable += '<tr style="background: #ddd; font-weight: bold;"><td colspan="2">' + className + '</td></tr>\n';
                        }
                        failTable += '<tr><td>' + atr.MethodName + '</td><td> ' + atr.message + '</td></tr>\n';
                    }
                    total++;
                }
            }
         
            failTable += '</table>';
         
            string body = '<p>' + passed + '/' + total + ' tests passed</p>\n';
            boolean allPassed = passed == total;
         
            if (!allPassed) {
                body += '<p>Test Failures:</p>\n' + failTable;
            }
         
            if ((allPassed && job.Automated_Test_Run__r.Email_on_Pass__c) || !allPassed) {
                Messaging.SingleEmailMessage mail = new Messaging.SingleEmailMessage();
                mail.setToAddresses(job.Automated_Test_Run__r.Emails__c.split('[,\\s]+'));
                mail.setSubject(job.Automated_Test_Run__r.Name + ' Automated Test Results: ' + (passed < total ? 'Fail' : 'Pass'));
                mail.setHtmlBody(body);
                System.debug(mail);
                messages.add(mail);
            }
        }   

        if (!Test.isRunningTest()) {
            Messaging.sendEmail(messages);
        }
     
        return messages;
    }
   
    //Recuurence procedure Starts----
   
     public PageReference RecuureceATSinsertandSchedule(){
       
        reccurenceMsg=false;
        List<Automated_Test_Run__c> ATSrecinsert=New List<Automated_Test_Run__c>();
        deleteCompletedJobs();
        String randomnumberis=generateRandomNumber();
        String RecrnceKeyword='%Test%';
        String ScheduleNameis='AutoTestRunnerRecurrence_'+RecrnceKeyword+'_'+randomnumberis;
        AtrRecord.Query__c=RecrnceKeyword;
        AtrRecord.Excluded_Classes__c=AtrRecord.Excluded_Classes__c;
        AtrRecord.Exclude_Managed_Packages__c=AtrRecord.Exclude_Managed_Packages__c;
     
        AtrRecord.Frequency__c=AtrRecord.Frequency__c;
        AtrRecord.On_Every__c=AtrRecord.On_Every__c;
        AtrRecord.Start_Date__c=AtrRecord.Start_Date__c;
        AtrRecord.End_Date__c=AtrRecord.End_Date__c;
        AtrRecord.Schedule_Name__c= ScheduleNameis;
        AtrRecord.Preferred_Time__c=AtrRecord.Preferred_Time__c;
     
        AtrRecord.RecordTypeId=ATERecordTypeId;
        ATSrecinsert.add(AtrRecord);
     
        Automated_Test_Run__c ATEemail = new Automated_Test_Run__c();
        ATEemail.Query__c=RecrnceKeyword;
        ATEemail.Emails__c=AtrRecord.Emails__c;
        ATEemail.Email_on_Pass__c=AtrRecord.Email_on_Pass__c;
        ATEemail.Schedule_Name__c= ScheduleNameis ;
        ATEemail.RecordTypeId=ATEmailRecordTypeId;
        ATSrecinsert.add(ATEemail);
        Savepoint sp = Database.setSavepoint();
        System.debug('Inserting record is Query'+AtrRecord.Query__c +'Frequency__c is'+AtrRecord.Frequency__c+ 'On_Every__c is'+AtrRecord.On_Every__c+'Start_Date__c is'+AtrRecord.Start_Date__c+'End_Date__c is'+AtrRecord.End_Date__c +'Preferred_Time__c'+AtrRecord.Preferred_Time__c);
        Date StartDateis=AtrRecord.Start_Date__c;
        Date EndDateis=AtrRecord.End_Date__c; 
        //Validation here
        reccurenceMsg=validateDates(StartDateis,EndDateis);
        if(reccurenceMsg==false){
            Integer Startyearis=StartDateis.year();
            Integer Endyearis=EndDateis.year();
            Integer StartmonthNum =StartDateis.month();
            Integer EndmonthNum = EndDateis.month();
            Map <Integer,String> monthNumbers = new Map <Integer,String> {1=>'Jan', 2=>'Feb',3=>'Mar',4=>'Apr', 5=>'May', 6=>'Jun',7=>'Jul',8=>'Aug', 9=>'Sep', 10=>'Oct', 11=>'Nov', 12=>'Dec'};
            String StartMonth=monthNumbers.get(StartmonthNum);
            String EndMonth=monthNumbers.get(EndmonthNum);
            string gvnDateis='?';
            //String Dateis='?';
            String Shddayofmonth='?';
            String Dayofweek='?';
            string Months=StartMonth+'-'+EndMonth;
            string Years=Startyearis+'-'+Endyearis;
            try{
                if(AtrRecord.Frequency__c=='Monthly'){
                    gvnDateis=AtrRecord.On_Every__c; 
                    //Date gvnDateis=date.parse(inputDate);
                     //gvnDateis = String.valueOf(StartDateis.day());             
                    } else if(AtrRecord.Frequency__c=='Weekly'){
                    Dayofweek=AtrRecord.On_Every__c;
                    //gvnDateis = String.valueOf(StartDateis.day());               
                }
               String formatedDates=gvnDateis.replaceAll(';', ',');
               String formatedDayofweek=Dayofweek.replaceAll(';', ',');
               
                    Map<String,string> Hoursformat=new Map<String,String> {'01:00 AM'=>'1','02:00 AM'=>'2','03:00 AM'=>'3','04:00 AM'=>'4','05:00 AM'=>'5','06:00 AM'=>'6','07:00 AM'=>'7',
                    '08:00 AM'=>'8','09:00 AM'=>'9','10:00 AM'=>'10','11:00 AM'=>'11','12:00 PM'=>'12','01:00 PM'=>'13','02:00 PM'=>'14','03:00 PM'=>'15','04:00 PM'=>'16','05:00 PM'=>'17',
                    '06:00 PM'=>'18','07:00 PM'=>'19','08:00 PM'=>'20','09:00 PM'=>'21','10:00 PM'=>'22','11:00 PM'=>'23','12:00 PM'=>'0'};

                    Map <String,String> DAYformat = new Map <String,String> {'SUNDAY'=>'SUN', 'MONDAY'=>'MON','TUESDAY'=>'TUE','WEDNESDAY'=>'WED','THURSDAY'=>'THU', 'FRIDAY'=>'FRI','SATURDAY'=>'SAT'};

                    String GetHour=Hoursformat.get(AtrRecord.Preferred_Time__c);
                    System.debug('***GetHour is***'+GetHour);
                    System.debug('***formatedDates is***'+formatedDates);
                    System.debug('***Months is***'+Months);
                    System.debug('***Dayofweek is***'+Dayofweek);
                    System.debug('***yearis is***'+Years);
                   
                    //Seconds   Minutes Hours   Day Of Month    Month   Day Of Week Year
                    String strSchedule = '0 ' + '0 '+GetHour+ ' ' +formatedDates+ ' ' +Months+ ' ' +formatedDayofweek+ ' ' + Years;
                    System.debug('***strSchedule***'+strSchedule);
                   AutoTestRunnerRecurrence.setup(strSchedule,ScheduleNameis); 

                        upsert ATSrecinsert;               
                       
            }
            catch(exception ex){
                Database.rollback(sp);
                ApexPages.addMessages(ex);
                reccurenceMsg=true;
                 //ApexPages.Message myMsg = new ApexPages.Message(ApexPages.Severity.INFO,'Job not Schedued Please give proper data+ex');
                // ApexPages.addMessage(myMsg);
            }
        }
        PageReference pageRef;
        System.debug('reccurenceMsg is '+reccurenceMsg);
        System.debug('pageRef is '+pageRef);
        if(reccurenceMsg==true && reccurenceMsg!=false){
            pageRef=null;         
        }else if(reccurenceMsg==false){         
            pageRef = new PageReference('/apex/AutomatedTestSetupRecurrence');
                    pageRef.setRedirect(true);
                    return pageRef; 
        }
         System.debug('reccurenceMsg is 2'+reccurenceMsg);
        System.debug('pageRef is 2 '+pageRef);                       
     return pageRef;
    }
   
    public boolean validateDates(date StartDateis,date EndDateis) {
        reccurenceMsg=false;
        date today= date.today();
        if(StartDateis>=EndDateis){
            reccurenceMsg=true;                   
            ApexPages.Message myMsg = new ApexPages.Message(ApexPages.Severity.INFO,'Start Date cannot be less than End Date and also both dates not same');
            ApexPages.addMessage(myMsg);
        } else if(StartDateis < today ){
            reccurenceMsg=true;
            ApexPages.Message myMsg = new ApexPages.Message(ApexPages.Severity.INFO,'Start Date Must be Greater than Today');
            ApexPages.addMessage(myMsg);
        }else if(EndDateis < today ){
            reccurenceMsg=true;
            ApexPages.Message myMsg = new ApexPages.Message(ApexPages.Severity.INFO,'End Date Must be Greater than Today');
            ApexPages.addMessage(myMsg);
        }
        return reccurenceMsg;
    }
    public void refreshHasRecrnsScheduledJobs() {
        List<CronTrigger> Schdjobs=New  List<CronTrigger>();
        integer jobCount = [SELECT count() FROM CronTrigger  where CronJobDetail.Name like '%AutoTestRunnerRecurrence%'];
        Schdjobs=[SELECT CronJobDetail.Name,CreatedDate,NextFireTime,State FROM CronTrigger where CronJobDetail.Name like '%AutoTestRunner%' and State in('WAITING','ACQUIRED','EXECUTING')];
        if(Schdjobs.size()>0){
            Jobstatus=Schdjobs[0].State;
            if(Schdjobs[0].NextFireTime!=null ){
            Datetime shddatetimeGSt=Schdjobs[0].NextFireTime;
            Datetime gmt = shddatetimeGSt;
             String timeZone = UserInfo.getTimeZone().getID();
             Datetime GivenDateTime=shddatetimeGSt;// here you can user your dates e.g. createddate
              Datetime localdt=Datetime.valueOf(GivenDateTime);
              //showdatetime = string.valueOfGmt(local);
              shddatetime=localdt.format();
              }
              else if(Jobstatus!=null && Jobstatus!='') {
                  shddatetime='Test Scheduled Job Current State is '+Jobstatus;
              }
            }           
        hasRecScheduledJobs = jobCount !=0;         
    }
    public PageReference CancelRecurrenceJobs() {   
          //List<CronTrigger> jobsToAbort = [select id,Name from CronJobDetail where Name like 'AutoTestRunner%' and JobType = '7'];
          List<CronTrigger> jobsToAbort = [select Id from CronTrigger where CronJobDetail.JobType = '7' and CronJobDetail.Name like '%AutoTestRunnerRecurrence%'];
              if(jobsToAbort.size()>0){
                  for (CronTrigger job : jobsToAbort) {
                   System.abortJob(job.Id);
                   }
               }
               PageReference pageRef = new PageReference('/apex/AutomatedTestSetupRecurrence');
                    pageRef.setRedirect(true);
                    return pageRef;
    }
   
    public static list<ID> recurrenceenqueueTests() {
        list<Id> jobIds = new list<Id>();
        Id ATERecordTypeId = Schema.SObjectType.Automated_Test_Run__c.getRecordTypeInfosByName().get('Automated Test Execution').getRecordTypeId();
        Id ATEmilRecordTypeId = Schema.SObjectType.Automated_Test_Run__c.getRecordTypeInfosByName().get('Automated Test Email Notification').getRecordTypeId();
        Automated_Test_Run__c EmailRecord=[select Emails__c,Schedule_Name__c from Automated_Test_Run__c where RecordTypeId=:ATEmilRecordTypeId and Schedule_Name__c like '%AutoTestRunnerRecurrence%' order by createdDate DESC limit 1];
        string whereExcluded = '';
        string Keywordis = '';
        string ATRIDis = '';
        for (Automated_Test_Run__c run : [select Query__c, Excluded_Classes__c,
            Email_on_Pass__c, Exclude_Managed_Packages__c
            from Automated_Test_Run__c where Active__c = true and RecordTypeId=:ATERecordTypeId and Frequency__c!=null and Schedule_Name__c=:EmailRecord.Schedule_Name__c  order by createdDate DESC limit 1]) {
               ATRIDis=run.id;
                if (run.Excluded_Classes__c != null) {
                    for (string c : run.Excluded_Classes__c.split('[,\\s]+')) {
                        whereExcluded += 'and Name != \'' + c + '\'';
                    }
                }
                if (run.Exclude_Managed_Packages__c == True) {
                   whereExcluded += ' AND NameSpacePrefix = null';
                }
                if (run.Query__c != null && run.Query__c != ' ' ) {
                   Keywordis +=run.Query__c;
                }
           }
            string query = 'SELECT Id FROM ApexClass WHERE Name LIKE \'' + Keywordis+ '\' ' + whereExcluded;
            ApexClass[] testClasses = Database.query(query);
             
            if (testClasses.size() > 0) {
                ApexTestQueueItem[] queueItems = new List<ApexTestQueueItem>();
                for (ApexClass cls : testClasses) {
                    queueItems.add(new ApexTestQueueItem(ApexClassId=cls.Id));
                }
                if (!Test.isRunningTest()) {
                    DataBase.insert(queueItems,false);     
                    // Get the job ID of the first queue item returned.     
                    ApexTestQueueItem item =[SELECT ParentJobId FROM ApexTestQueueItem WHERE Id=:queueItems[0].Id LIMIT 1];                   
                    insert new Test_Runner_Job__c(Name = item.parentjobid, Automated_Test_Run__c = EmailRecord.Id);
                    jobIds.add(item.parentjobid);
                /*if(ATRIDis!='' && ATRIDis!=null){
                        Automated_Test_Run__c runATRrecd =[select id,Active__c from Automated_Test_Run__c where Id=:ATRIDis limit 1];
                           runATRrecd.Active__c = false;
                           update runATRrecd;
                   }
                   */
                }
            }           
        return jobIds;
    }
  public PageReference click(){ 
    System.debug('isChecked is ' +isChecked);
    PageReference pageRef;
         if(isChecked!=TRUE){
             isCheckedRec = true;
             System.debug('isCheckedRec is ' +isCheckedRec);
        pageRef = new PageReference('/apex/AutomatedTestSetupRecurrence');
         }
         else{
             isCheckedRec = false;
             pageRef = new PageReference('/apex/AutomatedTestSetup');
         }     
                    pageRef.setRedirect(true);
                    return pageRef;
         //return null;
     }
   
   public PageReference Adhocclick(){ 
    System.debug('isAdhocChecked is ' +isAdhocChecked);
    PageReference pageRef;
         if(isAdhocChecked!=TRUE){
             isAdhocChecked = true;
             System.debug('isAdhocChecked is ' +isAdhocChecked);
        pageRef = new PageReference('/apex/AutomatedTestSetupAdhoc');
         }
         else{
             isCheckedRec = false;
             pageRef = new PageReference('/apex/AutomatedTestSetupRecurrence');
         }     
                    pageRef.setRedirect(true);
                    return pageRef;
         //return null;
     }
   
    public PageReference Homeclick(){ 
        System.debug('isHomeChecked is ' +isHomeChecked);
        PageReference pageRef;
         if(isHomeChecked!=TRUE){
             isHomeChecked = true;
             System.debug('isHomeChecked is ' +isHomeChecked);
        pageRef = new PageReference('/apex/AutomatedTestSetup');
         }
         else{
             isCheckedRec = false;
             pageRef = new PageReference('/apex/AutomatedTestSetup');
         }     
                    pageRef.setRedirect(true);
                    return pageRef;
         //return null;
     }
   public static String generateRandomNumber(){       
       Decimal randomValue = 100000 * math.random();       
       String userCode = String.valueOf(randomValue);       
       userCode = userCode.substring(0,3);       
       return userCode;   
       }
     
    //multipleAdhocJobs

  public PageReference CancelAdhocJobs() {   
    System.debug('SelectedAdhocJobId is'+SelectedAdhocJobId);
     //String AbortJobID = ApexPages.CurrentPage().getParameters().get('SelectedAdhocJobId');
   
     /*if (SelectedAdhocJobId == null) {   
         //return;
      }  */
      // find the CronTrigger record within the collection
      for(CronTrigger a : Schdjobs){
           if (a.Id == SelectedAdhocJobId) {
            System.abortJob(a.Id);
            }
       } 

       PageReference pageRef = new PageReference('/apex/AutomatedTestSetup');
       pageRef.setRedirect(true);
      return pageRef;
  }
 
}

No comments:

Post a Comment