/**
* 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);
}
}