Add a (failing for now) test for extended partitions

This reproduces bug #28
This commit is contained in:
Aurélien Gâteau 2014-07-18 10:51:05 +02:00
parent 43f29b8058
commit 6f65a4b16c
2 changed files with 34 additions and 5 deletions

View File

@ -80,14 +80,14 @@ JobTests::initTestCase()
void
JobTests::testPartitionTable()
{
queuePartitionTableCreation();
queuePartitionTableCreation( PartitionTable::gpt );
m_runner.run();
}
void
JobTests::queuePartitionTableCreation()
JobTests::queuePartitionTableCreation( PartitionTable::TableType type)
{
auto job = new CreatePartitionTableJob( m_device.data(), PartitionTable::gpt );
auto job = new CreatePartitionTableJob( m_device.data(), type );
job->updatePreview();
m_queue.enqueue( job_ptr( job ) );
}
@ -128,7 +128,7 @@ Partition* firstFreePartition( PartitionNode* parent )
void
JobTests::testCreatePartition()
{
queuePartitionTableCreation();
queuePartitionTableCreation( PartitionTable::gpt );
CreatePartitionJob* job;
Partition* partition = firstFreePartition( m_device->partitionTable() );
@ -137,13 +137,40 @@ JobTests::testCreatePartition()
job->updatePreview();
m_queue.enqueue( job_ptr( job ) );
partition = firstFreePartition( m_device->partitionTable() );
job = newCreatePartitionJob( partition, PartitionRole( PartitionRole::Primary ), FileSystem::LinuxSwap, 10 * MB);
job->updatePreview();
m_queue.enqueue( job_ptr( job ) );
partition = firstFreePartition( m_device->partitionTable() );
job = newCreatePartitionJob( partition, PartitionRole( PartitionRole::Primary ), FileSystem::Btrfs, 10 * MB);
job->updatePreview();
m_queue.enqueue( job_ptr( job ) );
m_runner.run();
}
void
JobTests::testCreatePartitionExtended()
{
queuePartitionTableCreation( PartitionTable::msdos );
CreatePartitionJob* job;
Partition* partition = firstFreePartition( m_device->partitionTable() );
job = newCreatePartitionJob( partition, PartitionRole( PartitionRole::Primary ), FileSystem::Ext4, 10 * MB);
QVERIFY( job );
job->updatePreview();
m_queue.enqueue( job_ptr( job ) );
partition = firstFreePartition( m_device->partitionTable() );
job = newCreatePartitionJob( partition, PartitionRole( PartitionRole::Extended ), FileSystem::Unformatted, 10 * MB);
job->updatePreview();
m_queue.enqueue( job_ptr( job ) );
Partition* extendedPartition = job->partition();
job = newCreatePartitionJob( firstFreePartition( extendedPartition ), PartitionRole( PartitionRole::Logical ), FileSystem::Ext4, 10 * MB);
job->updatePreview();
m_queue.enqueue( job_ptr( job ) );
m_runner.run();
}

View File

@ -7,6 +7,7 @@
#include <core/device.h>
#include <core/partition.h>
#include <core/partitionrole.h>
#include <core/partitiontable.h>
#include <fs/filesystem.h>
// Qt
@ -37,13 +38,14 @@ private Q_SLOTS:
void initTestCase();
void testPartitionTable();
void testCreatePartition();
void testCreatePartitionExtended();
private:
QScopedPointer< Device > m_device;
Calamares::JobQueue m_queue;
QueueRunner m_runner;
void queuePartitionTableCreation();
void queuePartitionTableCreation( PartitionTable::TableType type );
CreatePartitionJob* newCreatePartitionJob( Partition* freeSpacePartition, PartitionRole, FileSystem::Type type, qint64 size );
};