mirror of
https://github.com/qgis/QGIS.git
synced 2025-02-27 00:33:48 -05:00
tests for layernodeproperty "showFeatureCount"
fixes https://github.com/opengisch/Vogelwarte_QField_2019/issues/4
This commit is contained in:
parent
72bc1395f1
commit
5e61afcfe7
@ -25,6 +25,7 @@
|
||||
#include "qgsofflineediting.h"
|
||||
#include "qgstest.h"
|
||||
#include "qgsvectorlayerref.h"
|
||||
#include "qgslayertree.h"
|
||||
|
||||
/**
|
||||
* \ingroup UnitTests
|
||||
@ -107,12 +108,21 @@ void TestQgsOfflineEditing::createSpatialiteAndSynchronizeBack()
|
||||
QCOMPARE( mpLayer->featureCount(), numberOfFeatures );
|
||||
QCOMPARE( mpLayer->fields().size(), numberOfFields );
|
||||
|
||||
//set on LayerTreeNode showFeatureCount property
|
||||
QgsLayerTreeLayer *layerTreelayer = QgsProject::instance()->layerTreeRoot()->findLayer( mpLayer->id() );
|
||||
layerTreelayer->setCustomProperty( QStringLiteral( "showFeatureCount" ), 1 );
|
||||
|
||||
//convert
|
||||
mOfflineEditing->convertToOfflineProject( offlineDataPath, offlineDbFile, layerIds, false, QgsOfflineEditing::SpatiaLite );
|
||||
|
||||
mpLayer = qobject_cast<QgsVectorLayer *>( QgsProject::instance()->mapLayers().first() );
|
||||
QCOMPARE( mpLayer->name(), QStringLiteral( "points (offline)" ) );
|
||||
QCOMPARE( mpLayer->featureCount(), numberOfFeatures );
|
||||
//check LayerTreeNode showFeatureCount property
|
||||
layerTreelayer = QgsProject::instance()->layerTreeRoot()->findLayer( mpLayer->id() );
|
||||
QCOMPARE( layerTreelayer->customProperty( QStringLiteral( "showFeatureCount" ), 0 ).toInt(), 1 );
|
||||
//unset on LayerTreeNode showFeatureCount property
|
||||
layerTreelayer->setCustomProperty( QStringLiteral( "showFeatureCount" ), 0 );
|
||||
|
||||
//synchronize back
|
||||
mOfflineEditing->synchronize();
|
||||
@ -121,6 +131,10 @@ void TestQgsOfflineEditing::createSpatialiteAndSynchronizeBack()
|
||||
QCOMPARE( mpLayer->name(), QStringLiteral( "points" ) );
|
||||
QCOMPARE( mpLayer->featureCount(), numberOfFeatures );
|
||||
QCOMPARE( mpLayer->fields().size(), numberOfFields );
|
||||
|
||||
//check LayerTreeNode showFeatureCount property
|
||||
layerTreelayer = QgsProject::instance()->layerTreeRoot()->findLayer( mpLayer->id() );
|
||||
QCOMPARE( layerTreelayer->customProperty( QStringLiteral( "showFeatureCount" ), 0 ).toInt(), 0 );
|
||||
}
|
||||
|
||||
void TestQgsOfflineEditing::createGeopackageAndSynchronizeBack()
|
||||
@ -134,6 +148,11 @@ void TestQgsOfflineEditing::createGeopackageAndSynchronizeBack()
|
||||
it.nextFeature( firstFeatureBeforeAction );
|
||||
|
||||
connect( mOfflineEditing, &QgsOfflineEditing::warning, this, []( const QString & title, const QString & message ) { qDebug() << title << message; } );
|
||||
|
||||
//set on LayerTreeNode showFeatureCount property
|
||||
QgsLayerTreeLayer *layerTreelayer = QgsProject::instance()->layerTreeRoot()->findLayer( mpLayer->id() );
|
||||
layerTreelayer->setCustomProperty( QStringLiteral( "showFeatureCount" ), 1 );
|
||||
|
||||
//convert
|
||||
mOfflineEditing->convertToOfflineProject( offlineDataPath, offlineDbFile, layerIds, false, QgsOfflineEditing::GPKG );
|
||||
|
||||
@ -142,6 +161,9 @@ void TestQgsOfflineEditing::createGeopackageAndSynchronizeBack()
|
||||
QCOMPARE( mpLayer->featureCount(), numberOfFeatures );
|
||||
//comparing with the number +1 because GPKG created an fid
|
||||
QCOMPARE( mpLayer->fields().size(), numberOfFields + 1 );
|
||||
//check LayerTreeNode showFeatureCount property
|
||||
layerTreelayer = QgsProject::instance()->layerTreeRoot()->findLayer( mpLayer->id() );
|
||||
QCOMPARE( layerTreelayer->customProperty( QStringLiteral( "showFeatureCount" ), 0 ).toInt(), 1 );
|
||||
|
||||
QgsFeature firstFeatureInAction;
|
||||
it = mpLayer->getFeatures();
|
||||
@ -159,6 +181,9 @@ void TestQgsOfflineEditing::createGeopackageAndSynchronizeBack()
|
||||
mpLayer->commitChanges();
|
||||
QCOMPARE( mpLayer->featureCount(), numberOfFeatures + 1 );
|
||||
|
||||
//unset on LayerTreeNode showFeatureCount property
|
||||
layerTreelayer->setCustomProperty( QStringLiteral( "showFeatureCount" ), 0 );
|
||||
|
||||
//synchronize back
|
||||
mOfflineEditing->synchronize();
|
||||
|
||||
@ -166,6 +191,10 @@ void TestQgsOfflineEditing::createGeopackageAndSynchronizeBack()
|
||||
QCOMPARE( mpLayer->name(), QStringLiteral( "points" ) );
|
||||
QCOMPARE( mpLayer->dataProvider()->featureCount(), numberOfFeatures + 1 );
|
||||
QCOMPARE( mpLayer->fields().size(), numberOfFields );
|
||||
//check LayerTreeNode showFeatureCount property
|
||||
layerTreelayer = QgsProject::instance()->layerTreeRoot()->findLayer( mpLayer->id() );
|
||||
QCOMPARE( layerTreelayer->customProperty( QStringLiteral( "showFeatureCount" ), 0 ).toInt(), 0 );
|
||||
|
||||
//get last feature
|
||||
QgsFeature f = mpLayer->getFeature( mpLayer->dataProvider()->featureCount() - 1 );
|
||||
qDebug() << "FID:" << f.id() << "Class:" << f.attribute( "Class" ).toString();
|
||||
|
Loading…
x
Reference in New Issue
Block a user