[contextualprocess] Tests for new lookup behavior
This commit is contained in:
parent
bdb208c079
commit
28bf4082b3
@ -22,6 +22,8 @@
|
|||||||
#ifndef CONTEXTUALPROCESSJOB_BINDING_H
|
#ifndef CONTEXTUALPROCESSJOB_BINDING_H
|
||||||
#define CONTEXTUALPROCESSJOB_BINDING_H
|
#define CONTEXTUALPROCESSJOB_BINDING_H
|
||||||
|
|
||||||
|
#include "Job.h"
|
||||||
|
|
||||||
#include <QList>
|
#include <QList>
|
||||||
#include <QPair>
|
#include <QPair>
|
||||||
#include <QString>
|
#include <QString>
|
||||||
|
@ -17,9 +17,15 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "Tests.h"
|
#include "Tests.h"
|
||||||
|
|
||||||
|
#include "Binding.h"
|
||||||
#include "ContextualProcessJob.h"
|
#include "ContextualProcessJob.h"
|
||||||
|
|
||||||
|
#include "GlobalStorage.h"
|
||||||
|
#include "JobQueue.h"
|
||||||
|
#include "utils/CalamaresUtilsSystem.h"
|
||||||
#include "utils/CommandList.h"
|
#include "utils/CommandList.h"
|
||||||
|
#include "utils/Logger.h"
|
||||||
#include "utils/Yaml.h"
|
#include "utils/Yaml.h"
|
||||||
|
|
||||||
#include <QtTest/QtTest>
|
#include <QtTest/QtTest>
|
||||||
@ -38,6 +44,22 @@ ContextualProcessTests::~ContextualProcessTests() {}
|
|||||||
void
|
void
|
||||||
ContextualProcessTests::initTestCase()
|
ContextualProcessTests::initTestCase()
|
||||||
{
|
{
|
||||||
|
Logger::setupLogLevel( Logger::LOGDEBUG );
|
||||||
|
|
||||||
|
// Ensure we have a system object, expect it to be a "bogus" one
|
||||||
|
CalamaresUtils::System* system = CalamaresUtils::System::instance();
|
||||||
|
QVERIFY( system );
|
||||||
|
QVERIFY( system->doChroot() );
|
||||||
|
|
||||||
|
// Ensure we have a system-wide GlobalStorage with /tmp as root
|
||||||
|
if ( !Calamares::JobQueue::instance() )
|
||||||
|
{
|
||||||
|
cDebug() << "Creating new JobQueue";
|
||||||
|
(void)new Calamares::JobQueue();
|
||||||
|
}
|
||||||
|
Calamares::GlobalStorage* gs
|
||||||
|
= Calamares::JobQueue::instance() ? Calamares::JobQueue::instance()->globalStorage() : nullptr;
|
||||||
|
QVERIFY( gs );
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -61,4 +83,107 @@ ContextualProcessTests::testProcessListSampleConfig()
|
|||||||
|
|
||||||
QCOMPARE( job.count(), 2 ); // Only "firmwareType" and "branding.shortVersion"
|
QCOMPARE( job.count(), 2 ); // Only "firmwareType" and "branding.shortVersion"
|
||||||
QCOMPARE( job.count( "firmwareType" ), 4 );
|
QCOMPARE( job.count( "firmwareType" ), 4 );
|
||||||
|
QCOMPARE( job.count( "branding.shortVersion" ), 2 ); // in the example config
|
||||||
|
}
|
||||||
|
|
||||||
|
void ContextualProcessTests::testFetch()
|
||||||
|
{
|
||||||
|
QVariantMap m;
|
||||||
|
// Some keys without sub-map
|
||||||
|
m.insert( QStringLiteral( "carrot" ), true );
|
||||||
|
m.insert( QStringLiteral( "tomato" ), QStringLiteral( "fruit" ) );
|
||||||
|
|
||||||
|
// A key with sub-map
|
||||||
|
{
|
||||||
|
QVariantMap names;
|
||||||
|
names.insert( QStringLiteral( "blackcurrant" ), QStringLiteral( "black" ) );
|
||||||
|
names.insert( QStringLiteral( "redcurrant" ), QStringLiteral( "red" ) );
|
||||||
|
names.insert( QStringLiteral( "knoebels" ), QStringLiteral( "green" ) );
|
||||||
|
names.insert( QStringLiteral( "strawberry" ), QStringLiteral( "red" ) );
|
||||||
|
m.insert( QStringLiteral( "berries" ), names );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Another key with sub-map
|
||||||
|
{
|
||||||
|
QVariantMap names;
|
||||||
|
names.insert( QStringLiteral( "ext4" ), 1 );
|
||||||
|
names.insert( QStringLiteral( "zfs" ), 2 );
|
||||||
|
names.insert( QStringLiteral( "swap" ), 2 );
|
||||||
|
m.insert( QStringLiteral( "filesystem_use" ), names );
|
||||||
|
}
|
||||||
|
|
||||||
|
QCOMPARE( m.count(), 4 );
|
||||||
|
|
||||||
|
Calamares::GlobalStorage* gs
|
||||||
|
= Calamares::JobQueue::instance() ? Calamares::JobQueue::instance()->globalStorage() : nullptr;
|
||||||
|
QVERIFY( gs );
|
||||||
|
|
||||||
|
// Copy the built-up-map into GS
|
||||||
|
for ( auto it = m.cbegin(); it != m.cend(); ++it )
|
||||||
|
{
|
||||||
|
gs->insert( it.key(), it.value() );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Testing of fetch()
|
||||||
|
{
|
||||||
|
ContextualProcessBinding b( QStringLiteral( "carrot" ) );
|
||||||
|
QString s;
|
||||||
|
QVERIFY( b.fetch( gs, s ) );
|
||||||
|
QCOMPARE( s, QStringLiteral( "true" ) ); // String representation of boolean true
|
||||||
|
}
|
||||||
|
{
|
||||||
|
ContextualProcessBinding b( QStringLiteral( "tomato" ) );
|
||||||
|
QString s;
|
||||||
|
QVERIFY( b.fetch( gs, s ) );
|
||||||
|
QCOMPARE( s, QStringLiteral( "fruit" ) );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
// Key not found
|
||||||
|
ContextualProcessBinding b( QStringLiteral( "parsnip" ) );
|
||||||
|
QString s = QStringLiteral( "white" );
|
||||||
|
QVERIFY( !b.fetch( gs, s ) );
|
||||||
|
QCOMPARE( s, QString() );
|
||||||
|
QVERIFY( s.isEmpty() );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
// Submap gets smashed
|
||||||
|
ContextualProcessBinding b( QStringLiteral( "berries" ) );
|
||||||
|
QString s;
|
||||||
|
QVERIFY( b.fetch( gs, s ) );
|
||||||
|
QVERIFY( s.contains( QStringLiteral( "QVariant" ) ) );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
// Compound lookup
|
||||||
|
ContextualProcessBinding b( QStringLiteral( "berries.strawberry" ) );
|
||||||
|
QString s;
|
||||||
|
QVERIFY( b.fetch( gs, s ) );
|
||||||
|
QCOMPARE( s, QStringLiteral( "red" ) );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
ContextualProcessBinding b( QStringLiteral( "berries.knoebels" ) );
|
||||||
|
QString s;
|
||||||
|
QVERIFY( b.fetch( gs, s ) );
|
||||||
|
QCOMPARE( s, QStringLiteral( "green" ) );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
ContextualProcessBinding b( QStringLiteral( "filesystem_use.ext4" ) );
|
||||||
|
QString s;
|
||||||
|
QVERIFY( b.fetch( gs, s ) );
|
||||||
|
QCOMPARE( s, QStringLiteral( "1" ) );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
ContextualProcessBinding b( QStringLiteral( "filesystem_use.zfs" ) );
|
||||||
|
QString s;
|
||||||
|
QVERIFY( b.fetch( gs, s ) );
|
||||||
|
QCOMPARE( s, QStringLiteral( "2" ) );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
// Key not found, compound
|
||||||
|
ContextualProcessBinding b( QStringLiteral( "filesystem_use.ufs" ) );
|
||||||
|
QString s = QStringLiteral( "ufs" );
|
||||||
|
QVERIFY( !b.fetch( gs, s ) );
|
||||||
|
QCOMPARE( s, QString() );
|
||||||
|
QVERIFY( s.isEmpty() );
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -32,6 +32,9 @@ private Q_SLOTS:
|
|||||||
void initTestCase();
|
void initTestCase();
|
||||||
// Check the sample config file is processed correctly
|
// Check the sample config file is processed correctly
|
||||||
void testProcessListSampleConfig();
|
void testProcessListSampleConfig();
|
||||||
|
|
||||||
|
// Variable binding lookup
|
||||||
|
void testFetch();
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user