summaryrefslogtreecommitdiffstats
path: root/tests/auto
diff options
context:
space:
mode:
authorGunnar Sletta <gunnar@trolltech.com>2010-02-16 14:50:15 (GMT)
committerGunnar Sletta <gunnar@trolltech.com>2010-02-18 11:55:40 (GMT)
commit2ec9f20ad7204ad1121a49d862d625821323f7b4 (patch)
tree194622d7dfbb7e344065bce21451de701d027e8f /tests/auto
parent46e254fcde0aa70851c7c82ebef474c12cf042ef (diff)
downloadQt-2ec9f20ad7204ad1121a49d862d625821323f7b4.zip
Qt-2ec9f20ad7204ad1121a49d862d625821323f7b4.tar.gz
Qt-2ec9f20ad7204ad1121a49d862d625821323f7b4.tar.bz2
Make threading use-cases work for X11
Diffstat (limited to 'tests/auto')
-rw-r--r--tests/auto/qgl_threads/tst_openglthreading.cpp40
1 files changed, 28 insertions, 12 deletions
diff --git a/tests/auto/qgl_threads/tst_openglthreading.cpp b/tests/auto/qgl_threads/tst_openglthreading.cpp
index f0c889c..408bfc8 100644
--- a/tests/auto/qgl_threads/tst_openglthreading.cpp
+++ b/tests/auto/qgl_threads/tst_openglthreading.cpp
@@ -45,6 +45,10 @@
#include <QtOpenGL/QtOpenGL>
#include "tst_openglthreading.h"
+#ifdef Q_WS_X11
+#include <private/qt_x11_p.h>
+#endif
+
#define RUNNING_TIME 5000
tst_OpenGLThreading::tst_OpenGLThreading(QObject *parent)
@@ -114,9 +118,9 @@ public:
{
setAutoBufferSwap(false);
}
-
+
void paintEvent(QPaintEvent *)
- {
+ {
m_thread->lock();
makeCurrent();
QPainter p(this);
@@ -339,10 +343,6 @@ public:
mutex.unlock();
};
- void sendResizeEvent(QResizeEvent *e) {
- QGLWidget::resizeEvent(e);
- }
-
QMutex mutex;
QSize newSize;
};
@@ -367,13 +367,13 @@ public:
while (time.elapsed() < RUNNING_TIME && !failure) {
+
m_widget->mutex.lock();
QSize s = m_widget->newSize;
m_widget->mutex.unlock();
+
if (s != m_size) {
- QResizeEvent e(s, m_size);
- m_widget->sendResizeEvent(&e);
- m_size = s;
+ glViewport(0, 0, s.width(), s.height());
}
if (QGLContext::currentContext() != m_widget->context()) {
@@ -392,9 +392,9 @@ public:
glReadPixels(w / 2, h / 2, 1, 1, GL_RGBA, GL_UNSIGNED_BYTE, &color);
m_widget->swapBuffers();
-
-
}
+
+ m_widget->doneCurrent();
}
bool failure;
@@ -438,6 +438,12 @@ void tst_OpenGLThreading::renderInThread()
widget.update(100 + value, 100 + value, 20, 20);
qApp->processEvents();
value = -value;
+
+#ifdef Q_WS_WIN
+ Sleep(100);
+#else
+ usleep(100 * 1000);
+#endif
}
QVERIFY(!thread.failure);
@@ -446,7 +452,17 @@ void tst_OpenGLThreading::renderInThread()
+int main(int argc, char **argv)
+{
+#ifdef Q_WS_X11
+ XInitThreads();
+#endif
-QTEST_MAIN(tst_OpenGLThreading);
+ QApplication app(argc, argv);
+ QTEST_DISABLE_KEYPAD_NAVIGATION \
+
+ tst_OpenGLThreading tc;
+ return QTest::qExec(&tc, argc, argv);
+}
#include "tst_openglthreading.moc"