Package org.apache.jorphan.collections

Examples of org.apache.jorphan.collections.SearchByClass$Test


  public void run() {
    log.info("Running the test!");
    running = true;

    SearchByClass testPlan = new SearchByClass(TestPlan.class);
    getTestTree().traverse(testPlan);
    Object[] plan = testPlan.getSearchResults().toArray();
    if (plan.length == 0) {
      System.err.println("Could not find the TestPlan!");
      log.error("Could not find the TestPlan!");
      System.exit(1);
    }
    if (((TestPlan) plan[0]).isSerialized()) {
      serialized = true;
    }
        JMeterContextService.startTest();
        try {
          compileTree();
      } catch (RuntimeException e) {
        log.error("Error occurred compiling the tree:",e);
        JMeterUtils.reportErrorToUser("Error occurred compiling the tree: - see log file");
        return; // no point continuing
        }
    /**
     * Notification of test listeners needs to happen after function
     * replacement, but before setting RunningVersion to true.
     */
    testListeners = new SearchByClass(TestListener.class);
    getTestTree().traverse(testListeners);
   
    //  Merge in any additional test listeners
    // currently only used by the function parser
    testListeners.getSearchResults().addAll(testList);
    testList.clear(); // no longer needed
   
    if (!startListenersLater )notifyTestListenersOfStart();
    getTestTree().traverse(new TurnElementsOn());
        if (startListenersLater)notifyTestListenersOfStart();

    List testLevelElements = new LinkedList(getTestTree().list(getTestTree().getArray()[0]));
    removeThreadGroups(testLevelElements);
    SearchByClass searcher = new SearchByClass(ThreadGroup.class);
    getTestTree().traverse(searcher);
    TestCompiler.initialize();
    // for each thread group, generate threads
    // hand each thread the sampler controller
    // and the listeners, and the timer
    Iterator iter = searcher.getSearchResults().iterator();

    /*
     * Here's where the test really starts. Run a Full GC now: it's no harm
     * at all (just delays test start by a tiny amount) and hitting one too
     * early in the test can impair results for short tests.
     */
    System.gc();

    notifier = new ListenerNotifier();

    schcdule_run = true;
    JMeterContextService.getContext().setSamplingStarted(true);
    int groupCount = 0;
        JMeterContextService.clearTotalThreads();
        startingGroups = true;
    while (iter.hasNext()) {
      groupCount++;
      ThreadGroup group = (ThreadGroup) iter.next();
      int numThreads = group.getNumThreads();
            JMeterContextService.addTotalThreads(numThreads);
      boolean onErrorStopTest = group.getOnErrorStopTest();
      boolean onErrorStopThread = group.getOnErrorStopThread();
      String groupName = group.getName();
      int rampUp = group.getRampUp();
      float perThreadDelay = ((float) (rampUp * 1000) / (float) numThreads);
      log.info("Starting " + numThreads + " threads for group " + groupName + ". Ramp up = " + rampUp + ".");

      if (onErrorStopTest) {
        log.info("Test will stop on error");
      } else if (onErrorStopThread) {
        log.info("Thread will stop on error");
      } else {
        log.info("Continue on error");
      }

            ListedHashTree threadGroupTree = (ListedHashTree) searcher.getSubTree(group);
            threadGroupTree.add(group, testLevelElements);
      for (int i = 0; running && i < numThreads; i++) {
                final JMeterThread jmeterThread = new JMeterThread(cloneTree(threadGroupTree), this, notifier);
                jmeterThread.setThreadNum(i);
        jmeterThread.setThreadGroup(group);
View Full Code Here


    this.monitor = monitor;
    threadVars = new JMeterVariables();
    testTree = test;
    compiler = new TestCompiler(testTree, threadVars);
    controller = (Controller) testTree.getArray()[0];
    SearchByClass threadListenerSearcher = new SearchByClass(TestListener.class);
    test.traverse(threadListenerSearcher);
    testListeners = threadListenerSearcher.getSearchResults();
    notifier = note;
    running = true;
  }
View Full Code Here

    this.monitor = monitor;
    threadVars = new JMeterVariables();
    testTree = test;
    compiler = new TestCompiler(testTree, threadVars);
    controller = (Controller) testTree.getArray()[0];
    SearchByClass threadListenerSearcher = new SearchByClass(TestListener.class);
    test.traverse(threadListenerSearcher);
    testListeners = threadListenerSearcher.getSearchResults();
    notifier = note;
    running = true;
  }
View Full Code Here

   *
   * @see java.lang.Runnable#run()
   */
  public void run() {
    log.info("running clientengine run method");
    testListeners = new SearchByClass(TestListener.class);
    getTestTree().traverse(testListeners);
    sampleListeners = new ConvertListeners();

    // TODO this is a temporary fix - see bug 23487
    try {
View Full Code Here

  public void run() {
    log.info("Running the test!");
    running = true;
    testList = new ArrayList();

    SearchByClass testPlan = new SearchByClass(TestPlan.class);
    getTestTree().traverse(testPlan);
    Object[] plan = testPlan.getSearchResults().toArray();
    if (plan.length == 0) {
      System.err.println("Could not find the TestPlan!");
      log.error("Could not find the TestPlan!");
      System.exit(1);
    }
    if (((TestPlan) plan[0]).isSerialized()) {
      serialized = true;
    }
        JMeterContextService.startTest();
    compileTree();
    /**
     * Notification of test listeners needs to happen after function
     * replacement, but before setting RunningVersion to true.
     */
    testListeners = new SearchByClass(TestListener.class);
    getTestTree().traverse(testListeners);
    Collection col = testListeners.getSearchResults();
    col.addAll(testList);
    testList = null;
    notifyTestListenersOfStart();
    getTestTree().traverse(new TurnElementsOn());

    List testLevelElements = new LinkedList(getTestTree().list(getTestTree().getArray()[0]));
    removeThreadGroups(testLevelElements);
    SearchByClass searcher = new SearchByClass(ThreadGroup.class);
    getTestTree().traverse(searcher);
    TestCompiler.initialize();
    // for each thread group, generate threads
    // hand each thread the sampler controller
    // and the listeners, and the timer
    JMeterThread[] threads;
    Iterator iter = searcher.getSearchResults().iterator();

    /*
     * Here's where the test really starts. Run a Full GC now: it's no harm
     * at all (just delays test start by a tiny amount) and hitting one too
     * early in the test can impair results for short tests.
     */
    System.gc();

    notifier = new ListenerNotifier();

    schcdule_run = true;
    JMeterContextService.getContext().setSamplingStarted(true);
    int groupCount = 0;
    while (iter.hasNext()) {
      groupCount++;
      ThreadGroup group = (ThreadGroup) iter.next();
      int numThreads = group.getNumThreads();
      boolean onErrorStopTest = group.getOnErrorStopTest();
      boolean onErrorStopThread = group.getOnErrorStopThread();
      String groupName = group.getName();
      int rampUp = group.getRampUp();
      float perThreadDelay = ((float) (rampUp * 1000) / (float) numThreads);
      threads = new JMeterThread[numThreads];

      log.info("Starting " + numThreads + " threads for group " + groupName + ". Ramp up = " + rampUp + ".");

      if (onErrorStopTest) {
        log.info("Test will stop on error");
      } else if (onErrorStopThread) {
        log.info("Thread will stop on error");
      } else {
        log.info("Continue on error");
      }

            ListedHashTree threadGroupTree = (ListedHashTree) searcher.getSubTree(group);
            threadGroupTree.add(group, testLevelElements);
      for (int i = 0; running && i < threads.length; i++) {
        threads[i] = new JMeterThread(cloneTree(threadGroupTree), this, notifier);
        threads[i].setThreadNum(i);
        threads[i].setThreadGroup(group);
View Full Code Here

        }
    }

    protected void setMode()
    {
        SearchByClass testPlan = new SearchByClass(TestPlan.class);
        getTestTree().traverse(testPlan);
        Object[] plan = testPlan.getSearchResults().toArray();
        ResultCollector.enableFunctionalMode(
            ((TestPlan) plan[0]).isFunctionalMode());
    }
View Full Code Here

    public void run()
    {
        log.info("Running the test!");
        running = true;

        SearchByClass testPlan = new SearchByClass(TestPlan.class);
        getTestTree().traverse(testPlan);
        Object[] plan = testPlan.getSearchResults().toArray();
        if (plan.length == 0){
      System.err.println("Could not find the TestPlan!");
          log.error("Could not find the TestPlan!");
          System.exit(1);
        }
        if (((TestPlan) plan[0]).isSerialized())
        {
            serialized = true;
        }
        compileTree();
        List testLevelElements =
            new LinkedList(getTestTree().list(getTestTree().getArray()[0]));
        removeThreadGroups(testLevelElements);
        SearchByClass searcher = new SearchByClass(ThreadGroup.class);
        testListeners = new SearchByClass(TestListener.class);
        setMode();
        getTestTree().traverse(testListeners);
        getTestTree().traverse(searcher);
        TestCompiler.initialize();
        //for each thread group, generate threads
        // hand each thread the sampler controller
        // and the listeners, and the timer
        JMeterThread[] threads;
        Iterator iter = searcher.getSearchResults().iterator();

        /*
         * Here's where the test really starts. Run a Full GC now: it's no
         * harm at all (just delays test start by a tiny amount) and
         * hitting one too early in the test can impair results for short
         * tests.
         */
        System.gc();
       
        if (iter.hasNext())
        {
            notifyTestListenersOfStart();
        }
        notifier = new ListenerNotifier();
       
        schcdule_run = true;
        JMeterContextService.getContext().setSamplingStarted(true);
        int groupCount = 0;
        while (iter.hasNext())
        {
          groupCount++;
            ThreadGroup group = (ThreadGroup) iter.next();
      int numThreads = group.getNumThreads();
      boolean onErrorStopTest = group.getOnErrorStopTest();
      boolean onErrorStopThread = group.getOnErrorStopThread();
      String groupName = group.getName();
      int rampUp = group.getRampUp();
      float perThreadDelay = ((float) (rampUp * 1000) / (float) numThreads);
            threads = new JMeterThread[numThreads];
     
            log.info("Starting " + numThreads + " threads for group "+ groupName
                + ". Ramp up = "+ rampUp + ".");
           
      if (onErrorStopTest) {
        log.info("Test will stop on error");
      } else if (onErrorStopThread) {
        log.info("Thread will stop on error");
      } else {
        log.info("Continue on error");
      }

            for (int i = 0; running && i < threads.length; i++)
            {
                ListedHashTree threadGroupTree =
                    (ListedHashTree) searcher.getSubTree(group);
                threadGroupTree.add(group, testLevelElements);
                threads[i] =
                    new JMeterThread(
                        cloneTree(threadGroupTree),
                        this,
View Full Code Here

    this.monitor = monitor;
    threadVars = new JMeterVariables();
    testTree = test;
    compiler = new TestCompiler(testTree,threadVars);
    controller = (Controller) testTree.getArray()[0];
    SearchByClass threadListenerSearcher = new SearchByClass(ThreadListener.class);
    test.traverse(threadListenerSearcher);
    threadListeners = threadListenerSearcher.getSearchResults();
    notifier = note;
  }
View Full Code Here

TOP

Related Classes of org.apache.jorphan.collections.SearchByClass$Test

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.