File indexing completed on 2024-09-08 09:32:39
0001 // SPDX-License-Identifier: LGPL-2.1-or-later 0002 // 0003 // SPDX-FileCopyrightText: 2006-2007 Torsten Rahn <tackat@kde.org> 0004 // SPDX-FileCopyrightText: 2007 Inge Wallin <ingwa@kde.org> 0005 // SPDX-FileCopyrightText: 2007 Tim Sutton <tim@linfiniti.com> 0006 // 0007 0008 #include <QApplication> 0009 #include "MarbleDirs.h" 0010 #include "MarbleWidget.h" 0011 0012 #include <QtGui> //needed because this is a gui test 0013 #include <QtCore> 0014 #include <QElapsedTimer> 0015 #include <QTest> 0016 0017 namespace Marble 0018 { 0019 0020 class MarbleWidgetSpeedTest: public QObject 0021 { 0022 Q_OBJECT 0023 private Q_SLOTS: 0024 void timeTest(); 0025 void initTestCase();// will be called before the first testfunction is executed. 0026 void cleanupTestCase();// will be called after the last testfunction was executed. 0027 void init(){};// will be called before each testfunction is executed. 0028 void cleanup(){};// will be called after every testfunction. 0029 private: 0030 MarbleWidget *m_marbleWidget; 0031 }; 0032 0033 void MarbleWidgetSpeedTest::initTestCase() 0034 { 0035 MarbleDirs::setMarbleDataPath( DATA_PATH ); 0036 MarbleDirs::setMarblePluginPath( PLUGIN_PATH ); 0037 m_marbleWidget = new MarbleWidget(); 0038 m_marbleWidget->show(); 0039 } 0040 void MarbleWidgetSpeedTest::cleanupTestCase() 0041 { 0042 delete m_marbleWidget; 0043 } 0044 void MarbleWidgetSpeedTest::timeTest() 0045 { 0046 m_marbleWidget->setMapThemeId( "plain/plain.dgml" ); 0047 m_marbleWidget->setZoom( 1500 ); 0048 // m_marbleWidget->resize( 800, 600 ); 0049 0050 QElapsedTimer t; 0051 //m_marbleWidget->setMapTheme( "plain/plain.dgml" ); 0052 //m_marbleWidget->setMapTheme( "bluemarble/bluemarble.dgml" ); 0053 0054 /* 0055 m_marbleWidget->setShowGrid( false ); 0056 m_marbleWidget->setShowPlaces( false ); 0057 m_marbleWidget->setShowBorders( false ); 0058 m_marbleWidget->setShowRivers( false ); 0059 m_marbleWidget->setShowLakes( false ); 0060 */ 0061 0062 t.start(); 0063 0064 for ( int j = 0; j < 10; ++j ) { 0065 for ( int k = 0; k < 10; ++k ) { 0066 m_marbleWidget->moveRight(); 0067 QCoreApplication::flush(); 0068 } 0069 for ( int k = 0; k < 10; ++k ) { 0070 m_marbleWidget->moveLeft(); 0071 QCoreApplication::flush(); 0072 } 0073 } 0074 0075 //required maximum elapsed time for test to pass 0076 QVERIFY(t.elapsed() < 10); 0077 //required frames per second for test to pass 0078 //redundant with above really but I leave it in 0079 //for now... 0080 unsigned int fps = (uint)( 200.0*1000.0/(double)(t.elapsed()) ); 0081 QVERIFY(fps > 10); 0082 0083 } 0084 0085 } 0086 0087 //QTEST_MAIN(MarbleWidgetSpeedTest) 0088 int main( int argc, char ** argv ) 0089 { 0090 QApplication app( argc, argv ); 0091 Marble::MarbleWidgetSpeedTest speedTest; 0092 QTest::qExec( &speedTest ); 0093 return 0; 0094 } 0095 0096 #include "MarbleWidgetSpeedTest.moc"