001: /*
002: * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
003: *
004: * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
005: *
006: * The contents of this file are subject to the terms of either the GNU General
007: * Public License Version 2 only ("GPL") or the Common Development and Distribution
008: * License("CDDL") (collectively, the "License"). You may not use this file except in
009: * compliance with the License. You can obtain a copy of the License at
010: * http://www.netbeans.org/cddl-gplv2.html or nbbuild/licenses/CDDL-GPL-2-CP. See the
011: * License for the specific language governing permissions and limitations under the
012: * License. When distributing the software, include this License Header Notice in
013: * each file and include the License file at nbbuild/licenses/CDDL-GPL-2-CP. Sun
014: * designates this particular file as subject to the "Classpath" exception as
015: * provided by Sun in the GPL Version 2 section of the License file that
016: * accompanied this code. If applicable, add the following below the License Header,
017: * with the fields enclosed by brackets [] replaced by your own identifying
018: * information: "Portions Copyrighted [year] [name of copyright owner]"
019: *
020: * Contributor(s):
021: *
022: * The Original Software is NetBeans. The Initial Developer of the Original Software
023: * is Sun Microsystems, Inc. Portions Copyright 1997-2007 Sun Microsystems, Inc. All
024: * Rights Reserved.
025: *
026: * If you wish your version of this file to be governed by only the CDDL or only the
027: * GPL Version 2, indicate your decision by adding "[Contributor] elects to include
028: * this software in this distribution under the [CDDL or GPL Version 2] license." If
029: * you do not indicate a single choice of license, a recipient has the option to
030: * distribute your version of this file under either the CDDL, the GPL Version 2 or
031: * to extend the choice of license to its licensees as provided above. However, if
032: * you add GPL Version 2 code and therefore, elected the GPL Version 2 license, then
033: * the option applies only if the new code is made subject to such option by the
034: * copyright holder.
035: */
036:
037: package org.downloader;
038:
039: import java.io.File;
040: import java.net.MalformedURLException;
041: import java.net.URL;
042: import org.MyTestCase;
043: import org.netbeans.installer.downloader.DownloadConfig;
044: import org.netbeans.installer.downloader.Pumping;
045: import org.netbeans.installer.downloader.queue.DispatchedQueue;
046: import org.netbeans.installer.downloader.services.EmptyQueueListener;
047: import org.server.WithServerTestCase;
048:
049: /**
050: *
051: * @author Danila_Dugurov
052: */
053: public class QueueAndListenerWithServerTest extends WithServerTestCase {
054:
055: public void testFailedDwonload() throws MalformedURLException {
056: final DispatchedQueue queue = new DispatchedQueue(new File(
057: MyTestCase.testWD, "queueState.xml"));
058: final VerboseTracer listener = new VerboseTracer(queue);
059: EmptyQueueListener notifier = new EmptyQueueListener() {
060: public void pumpingStateChange(String id) {
061: System.out.println(queue.getById(id).state());
062: if (queue.getById(id).state() == Pumping.State.FAILED) {
063: synchronized (queue) {
064: queue.notifyAll();
065: }
066: }
067: }
068: };
069: queue.addListener(notifier);
070: queue.invoke();
071: queue.add(new URL("http://www.oblom.com:8080/oblom.data"));
072: synchronized (queue) {
073: try {
074: queue.wait();
075: } catch (InterruptedException ex) {
076: ex.printStackTrace();
077: }
078: }
079: queue.terminate();
080: assertEquals(2 + DownloadConfig.ATTEMPT_COUNT * 2 + 2,
081: listener.verboseActions.size());
082: assertEquals("invoke", listener.verboseActions.get(0)
083: .getFirst());
084: assertEquals("add", listener.verboseActions.get(1).getFirst());
085: for (int i = 2; i < 2 + DownloadConfig.ATTEMPT_COUNT * 2; i += 2) {
086: assertEquals("stateChange", listener.verboseActions.get(i)
087: .getFirst());
088: assertEquals(Pumping.State.CONNECTING.toString(),
089: listener.verboseActions.get(i).getSecond()[1]);
090: assertEquals("stateChange", listener.verboseActions.get(
091: i + 1).getFirst());
092: assertEquals(Pumping.State.WAITING.toString(),
093: listener.verboseActions.get(i + 1).getSecond()[1]);
094: }
095: assertEquals(Pumping.State.FAILED.toString(),
096: listener.verboseActions.get(
097: 2 + DownloadConfig.ATTEMPT_COUNT * 2)
098: .getSecond()[1]);
099: assertEquals("terminate", listener.verboseActions.get(
100: 2 + DownloadConfig.ATTEMPT_COUNT * 2 + 1).getFirst());
101: }
102: }
|