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