/* * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package com.iwebpp.libuvpp.tests; import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicInteger; import android.util.Log; import com.iwebpp.libuvpp.cb.TimerCallback; import com.iwebpp.libuvpp.handles.HandleFactory; import com.iwebpp.libuvpp.handles.LoopHandle; import com.iwebpp.libuvpp.handles.TimerHandle; import static com.iwebpp.libuvpp.handles.DefaultHandleFactory.newFactory; public class TimerHandleTest extends TestBase { private static final String TAG = "TimerHandleTest"; private static final int TIMES = 100; /// @Test public void testOnce() throws Throwable { final AtomicBoolean gotCallback = new AtomicBoolean(false); final AtomicBoolean gotClose = new AtomicBoolean(false); final HandleFactory handleFactory = newFactory(); final LoopHandle loop = handleFactory.getLoopHandle(); final TimerHandle timer = handleFactory.newTimerHandle(); timer.setCloseCallback(new TimerCallback() { @Override public void onTimer(final int i) throws Exception { System.out.println("timer closed"); gotClose.set(true); } }); timer.setTimerFiredCallback(new TimerCallback() { @Override public void onTimer(final int status) throws Exception { gotCallback.set(true); System.out.println("timer fired once"); timer.close(); } }); timer.start(100, 0); final long start = System.currentTimeMillis(); while (!gotCallback.get() || !gotClose.get()) { if (System.currentTimeMillis() - start > TestBase.TIMEOUT) { ///Assert.fail("timeout waiting for timer"); } loop.runNoWait(); } ///Assert.assertTrue(gotCallback.get()); ///Assert.assertTrue(gotClose.get()); } /// @Test public void testRepeat() throws Throwable { final AtomicBoolean gotCallback = new AtomicBoolean(false); final AtomicBoolean gotClose = new AtomicBoolean(false); final AtomicInteger callbackCount = new AtomicInteger(0); final LoopHandle loop = new LoopHandle(); final TimerHandle timer = new TimerHandle(loop); timer.setCloseCallback(new TimerCallback() { @Override public void onTimer(final int i) throws Exception { System.out.println("repeat timer closed"); gotClose.set(true); } }); timer.setTimerFiredCallback(new TimerCallback() { @Override public void onTimer(final int status) throws Exception { gotCallback.set(true); if (callbackCount.incrementAndGet() == TIMES) { System.out.println("closing repeat timer"); gotClose.set(true); } System.out.println("timer fired " + callbackCount.get()); } }); timer.start(50, 5); final long start = System.currentTimeMillis(); while (!gotCallback.get() || !gotClose.get()) { if (System.currentTimeMillis() - start > TestBase.TIMEOUT) { ///Assert.fail("timeout waiting for timer"); } loop.runNoWait(); } ///Assert.assertTrue(gotCallback.get()); ///Assert.assertTrue(gotClose.get()); ///Assert.assertTrue(callbackCount.get() == TIMES); } ///public static void main(final String[] args) throws Throwable { public void run() { Log.d(TAG, "start test"); final TimerHandleTest test = new TimerHandleTest(); try { test.testOnce(); } catch (Throwable e) { e.printStackTrace(); } /*try { test.testRepeat(); } catch (Throwable e) { e.printStackTrace(); }*/ } }