aboutsummaryrefslogtreecommitdiffstats
path: root/test/com/jogamp/opencl/gl
diff options
context:
space:
mode:
authorMichael Bien <[email protected]>2010-04-24 05:01:43 +0200
committerMichael Bien <[email protected]>2010-04-24 05:01:43 +0200
commit7543640d906f7ae2339faa40d0fc019c7a787593 (patch)
tree584d9f0624f35bfa07c067d90c962210e348995b /test/com/jogamp/opencl/gl
parentbec58034b631656d3ec436ea350fa1652a8f9195 (diff)
CLGLContext.create() makes GLContext current.
made CLContext.release() more bulletproof. added CLGLTest.
Diffstat (limited to 'test/com/jogamp/opencl/gl')
-rw-r--r--test/com/jogamp/opencl/gl/CLGLTest.java95
1 files changed, 95 insertions, 0 deletions
diff --git a/test/com/jogamp/opencl/gl/CLGLTest.java b/test/com/jogamp/opencl/gl/CLGLTest.java
new file mode 100644
index 00000000..278206cf
--- /dev/null
+++ b/test/com/jogamp/opencl/gl/CLGLTest.java
@@ -0,0 +1,95 @@
+/*
+ * Created on Saturday, April 24 2010 02:58 AM
+ */
+
+package com.jogamp.opencl.gl;
+
+import com.jogamp.opencl.CLDevice;
+import com.jogamp.newt.Display;
+import com.jogamp.newt.NewtFactory;
+import com.jogamp.newt.Screen;
+import com.jogamp.newt.Window;
+import com.jogamp.newt.opengl.GLWindow;
+import com.jogamp.opencl.CLContext;
+import com.jogamp.opencl.CLPlatform;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.GLProfile;
+import org.junit.AfterClass;
+import org.junit.BeforeClass;
+import javax.media.opengl.GLContext;
+import org.junit.Test;
+
+import static org.junit.Assert.*;
+import static java.lang.System.*;
+
+/**
+ * Test testing the JOGL - JOCL interoperability.
+ * @author Michael Bien
+ */
+public class CLGLTest {
+
+ private static GLContext glcontext;
+
+ @BeforeClass
+ public static void init() {
+
+ Display display = NewtFactory.createDisplay(null); // local display
+ assertNotNull(display);
+
+ Screen screen = NewtFactory.createScreen(display, 0); // screen 0
+ assertNotNull(screen);
+
+ Window window = NewtFactory.createWindow(screen, new GLCapabilities(GLProfile.getDefault()), false /* undecorated */);
+ assertNotNull(window);
+
+ window.setSize(640, 480);
+
+ GLWindow glWindow = GLWindow.create(window);
+ assertNotNull(glWindow);
+ glWindow.setVisible(true);
+
+ glcontext = glWindow.getContext();
+ }
+
+ @AfterClass
+ public static void release() {
+ if(glcontext!= null) {
+ glcontext.destroy();
+ glcontext = null;
+ }
+ }
+
+ @Test
+ public void createContextTest() {
+
+ out.println(" - - - glcl; createContextTest - - - ");
+
+ CLDevice[] devices = CLPlatform.getDefault().listCLDevices();
+ CLDevice device = null;
+ for (CLDevice d : devices) {
+ if(d.isGLMemorySharingSupported()) {
+ device = d;
+ break;
+ }
+ }
+
+ if(device == null) {
+ out.println("Aborting test: no GLCL capable devices found.");
+ return;
+ }
+
+ CLContext context = CLGLContext.create(glcontext, device);
+ assertNotNull(context);
+// assertTrue(glcontext.isCurrent());
+
+ try{
+ out.println(context);
+ }finally{
+ context.release();
+ }
+
+
+ }
+
+
+}