mirror of
https://github.com/qgis/QGIS.git
synced 2025-03-22 00:06:57 -04:00
fix test and add test cases
This commit is contained in:
parent
be9f6bb97a
commit
73e3eadfc9
@ -143,13 +143,14 @@ void TestQgsOfflineEditing::createGeopackageAndSynchronizeBack()
|
|||||||
it.nextFeature( firstFeatureInAction );
|
it.nextFeature( firstFeatureInAction );
|
||||||
|
|
||||||
//compare some values
|
//compare some values
|
||||||
QCOMPARE( firstFeatureInAction.attribute( "Class" ).toString(), firstFeatureBeforeAction.attribute( "Class" ).toString() );
|
QCOMPARE( firstFeatureInAction.attribute( QStringLiteral( "Class" ) ).toString(), firstFeatureBeforeAction.attribute( QStringLiteral( "Class" ) ).toString() );
|
||||||
QCOMPARE( firstFeatureInAction.attribute( "Heading" ).toString(), firstFeatureBeforeAction.attribute( "Heading" ).toString() );
|
QCOMPARE( firstFeatureInAction.attribute( QStringLiteral( "Heading" ) ).toString(), firstFeatureBeforeAction.attribute( QStringLiteral( "Heading" ) ).toString() );
|
||||||
QCOMPARE( firstFeatureInAction.attribute( "Cabin Crew" ).toString(), firstFeatureBeforeAction.attribute( "Cabin Crew" ).toString() );
|
QCOMPARE( firstFeatureInAction.attribute( QStringLiteral( "Cabin Crew" ) ).toString(), firstFeatureBeforeAction.attribute( QStringLiteral( "Cabin Crew" ) ).toString() );
|
||||||
|
|
||||||
QgsFeature newFeature( mpLayer->fields() );
|
QgsFeature newFeature( mpLayer->dataProvider()->fields() );
|
||||||
|
newFeature.setAttribute( QStringLiteral( "Class" ), QStringLiteral( "Superjet" ) );
|
||||||
mpLayer->startEditing();
|
mpLayer->startEditing();
|
||||||
mpLayer->dataProvider()->addFeature( newFeature );
|
mpLayer->addFeature( newFeature );
|
||||||
mpLayer->commitChanges();
|
mpLayer->commitChanges();
|
||||||
QCOMPARE( mpLayer->featureCount(), numberOfFeatures + 1 );
|
QCOMPARE( mpLayer->featureCount(), numberOfFeatures + 1 );
|
||||||
|
|
||||||
@ -158,15 +159,24 @@ void TestQgsOfflineEditing::createGeopackageAndSynchronizeBack()
|
|||||||
|
|
||||||
mpLayer = qobject_cast<QgsVectorLayer *>( QgsProject::instance()->mapLayers().first() );
|
mpLayer = qobject_cast<QgsVectorLayer *>( QgsProject::instance()->mapLayers().first() );
|
||||||
QCOMPARE( mpLayer->name(), QStringLiteral( "points" ) );
|
QCOMPARE( mpLayer->name(), QStringLiteral( "points" ) );
|
||||||
//following it's failing and I don't know why
|
QCOMPARE( mpLayer->dataProvider()->featureCount(), numberOfFeatures + 1 );
|
||||||
//QCOMPARE( mpLayer->dataProvider()->featureCount(), numberOfFeatures + 1 );
|
|
||||||
QCOMPARE( mpLayer->fields().size(), numberOfFields );
|
QCOMPARE( mpLayer->fields().size(), numberOfFields );
|
||||||
|
//get last feature
|
||||||
|
QgsFeature f = mpLayer->getFeature( mpLayer->dataProvider()->featureCount() - 1 );
|
||||||
|
qDebug() << "FID:" << f.id() << "Class:" << f.attribute( "Class" ).toString();
|
||||||
|
QCOMPARE( f.attribute( QStringLiteral( "Class" ) ).toString(), QStringLiteral( "Superjet" ) );
|
||||||
|
|
||||||
QgsFeature firstFeatureAfterAction;
|
QgsFeature firstFeatureAfterAction;
|
||||||
it = mpLayer->getFeatures();
|
it = mpLayer->getFeatures();
|
||||||
it.nextFeature( firstFeatureAfterAction );
|
it.nextFeature( firstFeatureAfterAction );
|
||||||
|
|
||||||
QCOMPARE( firstFeatureAfterAction, firstFeatureBeforeAction );
|
QCOMPARE( firstFeatureAfterAction, firstFeatureBeforeAction );
|
||||||
|
|
||||||
|
//and delete the feature again
|
||||||
|
QgsFeatureIds idsToClean;
|
||||||
|
idsToClean << f.id();
|
||||||
|
mpLayer->dataProvider()->deleteFeatures( idsToClean );
|
||||||
|
QCOMPARE( mpLayer->dataProvider()->featureCount(), numberOfFeatures );
|
||||||
}
|
}
|
||||||
|
|
||||||
QGSTEST_MAIN( TestQgsOfflineEditing )
|
QGSTEST_MAIN( TestQgsOfflineEditing )
|
||||||
|
Loading…
x
Reference in New Issue
Block a user