/** * Copyright 2010 JogAmp Community. All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, are * permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, this list of * conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright notice, this list * of conditions and the following disclaimer in the documentation and/or other materials * provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY JogAmp Community ``AS IS'' AND ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JogAmp Community OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * The views and conclusions contained in the software and documentation are those of the * authors and should not be interpreted as representing official policies, either expressed * or implied, of JogAmp Community. */ package com.jogamp.opengl.test.junit.jogl.acore; import java.io.IOException; import com.jogamp.opengl.GLCapabilities; import com.jogamp.opengl.GLProfile; import org.junit.AfterClass; import org.junit.Assert; import org.junit.Test; import org.junit.FixMethodOrder; import org.junit.runners.MethodSorters; import com.jogamp.common.os.Platform; import com.jogamp.newt.opengl.GLWindow; import com.jogamp.opengl.JoglVersion; import com.jogamp.opengl.test.junit.jogl.demos.es2.GearsES2; import com.jogamp.opengl.test.junit.util.UITestCase; import com.jogamp.opengl.util.Animator; @FixMethodOrder(MethodSorters.NAME_ASCENDING) public class TestShutdownCompleteNEWT extends UITestCase { static long duration = 300; // ms protected void runTestGL(final boolean onscreen) throws InterruptedException { final GLCapabilities caps = new GLCapabilities(GLProfile.getGL2ES2()); caps.setOnscreen(onscreen); caps.setPBuffer(!onscreen); final GLWindow glWindow = GLWindow.create(caps); Assert.assertNotNull(glWindow); glWindow.setTitle("Gears NEWT Test"); glWindow.addGLEventListener(new GearsES2()); final Animator animator = new Animator(glWindow); glWindow.setSize(256, 256); glWindow.setVisible(true); animator.setUpdateFPSFrames(60, System.err); animator.start(); Assert.assertEquals(true, animator.isAnimating()); Assert.assertEquals(true, glWindow.isVisible()); Assert.assertEquals(true, glWindow.isNativeValid()); Assert.assertEquals(true, glWindow.isRealized()); while(animator.isAnimating() && animator.getTotalFPSDuration()<duration) { Thread.sleep(100); } animator.stop(); glWindow.destroy(); } @AfterClass public static void afterAll() { if(waitForKey) { UITestCase.waitForKey("Exit"); } } protected void oneLife(final boolean glInfo) throws InterruptedException { if(waitForEach) { UITestCase.waitForKey("Start One Life"); } final long t0 = Platform.currentTimeMicros(); GLProfile.initSingleton(); final long t1 = Platform.currentTimeMicros(); if(!initOnly) { runTestGL(true); } final long t2 = Platform.currentTimeMicros(); if(glInfo) { System.err.println(JoglVersion.getDefaultOpenGLInfo(null, null, false).toString()); } final long t3 = Platform.currentTimeMicros(); GLProfile.shutdown(); final long t4 = Platform.currentTimeMicros(); System.err.println("Total: "+ (t4-t0)/1e3 +"ms"); System.err.println(" GLProfile.initSingleton(): "+ (t1-t0)/1e3 +"ms"); System.err.println(" Demo Code: "+ (t2-t1)/1e3 +"ms"); System.err.println(" GLInfo: "+ (t3-t2)/1e3 +"ms"); System.err.println(" GLProfile.shutdown(): "+ (t4-t3)/1e3 +"ms"); } @Test public void test01OneLife() throws InterruptedException { oneLife(false); } @Test public void test02AnotherLifeWithGLInfo() throws InterruptedException { oneLife(true); } @Test public void test03AnotherLife() throws InterruptedException { oneLife(true); } @Test public void test03TwoLifes() throws InterruptedException { oneLife(false); oneLife(false); } static boolean initOnly = false; static boolean waitForEach = false; static boolean waitForKey = false; public static void main(final String args[]) throws IOException { for(int i=0; i<args.length; i++) { if(args[i].equals("-wait")) { waitForKey = true; } else if(args[i].equals("-waitForEach")) { waitForEach = true; waitForKey = true; } else if(args[i].equals("-initOnly")) { initOnly = true; } } if(waitForKey) { UITestCase.waitForKey("Start"); } final String tstname = TestShutdownCompleteNEWT.class.getName(); org.junit.runner.JUnitCore.main(tstname); } }