buildframework/helium/sf/java/legacy/src/com/nokia/ant/conditions/AtsCondition.java
author wbernard
Tue, 27 Apr 2010 08:33:08 +0300
changeset 587 85df38eb4012
child 588 c7c26511138f
permissions -rw-r--r--
helium_9.0-a7879c935424
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     1
/*
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     2
* Copyright (c) 2007-2008 Nokia Corporation and/or its subsidiary(-ies).
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     3
* All rights reserved.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     4
* This component and the accompanying materials are made available
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     6
* which accompanies this distribution, and is available
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     8
*
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     9
* Initial Contributors:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    11
*
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    12
* Contributors:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    13
*
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    14
* Description: 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    15
*
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    16
*/
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    17
 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    18
package com.nokia.ant.conditions;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    19
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    20
import org.apache.log4j.Logger;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    21
import org.apache.tools.ant.ProjectComponent;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    22
import org.apache.tools.ant.taskdefs.condition.Condition;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    23
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    24
import java.util.Iterator;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    25
import java.net.MalformedURLException;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    26
import java.net.URL;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    27
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    28
import org.dom4j.Document;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    29
import org.dom4j.DocumentException;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    30
import org.dom4j.Element;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    31
import org.dom4j.io.SAXReader;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    32
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    33
/**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    34
 * Condition to read check from diamonds and tell if ats has failed
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    35
 * @ant.type name="hasAtsPassed"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    36
 */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    37
public class AtsCondition extends ProjectComponent implements Condition
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    38
{
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    39
    private Logger log = Logger.getLogger(AtsCondition.class);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    40
    private int sleeptimesecs = 60;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    41
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    42
    public void setSleeptime(int seconds)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    43
    {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    44
        sleeptimesecs = seconds;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    45
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    46
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    47
    /** Read from diamonds and signal if ats failed */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    48
    public boolean eval()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    49
    {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    50
        String bid = getProject().getProperty("diamonds.build.id");
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    51
        if (bid == null)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    52
            log.info("Diamonds not enabled");
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    53
        else
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    54
        {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    55
            boolean testsfound = false;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    56
            log.info("Looking for tests in diamonds");
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    57
            SAXReader xmlReader = new SAXReader();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    58
            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    59
            while (!testsfound)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    60
            {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    61
                Document antDoc = null;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    62
                
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    63
                try {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    64
                    URL url = new URL("http://" + getProject().getProperty("diamonds.host") + bid + "?fmt=xml");
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    65
                    antDoc = xmlReader.read(url);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    66
                } catch (MalformedURLException  e) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    67
                    // We are Ignoring the errors as no need to fail the build.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    68
                    log.error("Not able to read the Diamonds URL http://" + getProject().getProperty("diamonds.host") + bid + "?fmt=xml: " + e.getMessage());
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    69
                } catch (DocumentException e) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    70
                    log.error("Not able to read the Diamonds URL http://" + getProject().getProperty("diamonds.host") + bid + "?fmt=xml: " + e.getMessage());
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    71
                }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    72
                  
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    73
                for (Iterator iterator = antDoc.selectNodes("//test/failed").iterator(); iterator.hasNext();)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    74
                {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    75
                    testsfound = true;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    76
                    Element e = (Element) iterator.next();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    77
                    String failed = e.getText();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    78
                    if (!failed.equals("0"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    79
                    {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    80
                        log.error("ATS tests failed");
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    81
                        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    82
                        for (Iterator iterator2 = antDoc.selectNodes("//actual_result").iterator(); iterator2.hasNext();)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    83
                        {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    84
                            Element e2 = (Element) iterator2.next();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    85
                            log.error(e2.getText());
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    86
                        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    87
                        return false;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    88
                    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    89
                }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    90
                
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    91
                int noofdrops = Integer.parseInt(getProject().getProperty("drop.file.counter"));
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    92
                if (noofdrops > 0)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    93
                {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    94
                    int testsrun = antDoc.selectNodes("//test").size();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    95
                    if (testsrun < noofdrops)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    96
                    {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    97
                        log.info(testsrun + " test completed, " + noofdrops + " total");
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    98
                        testsfound = false;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    99
                    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   100
                }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   101
                if (!testsfound)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   102
                {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   103
                    log.info("Tests not found sleeping for " + sleeptimesecs + " seconds");
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   104
                    try {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   105
                    Thread.sleep(sleeptimesecs * 1000);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   106
                    } catch (InterruptedException e) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   107
                        // This will not affect the build process so ignoring.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   108
                        log.debug("Interrupted while reading ATS build status " + e.getMessage());
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   109
                    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   110
                }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   111
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   112
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   113
        return true;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   114
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   115
}