Isis 3 Programmer Reference
|
#include <CubeDataThreadTester.h>
Public Slots | |
void | ReadBrick (void *requester, int cubeId, const Isis::Brick *data) |
This is called when a brick is read. | |
void | ReadWriteBrick (void *requester, int cubeId, Isis::Brick *data) |
This is called when a brick is given for R/W. | |
void | BrickChanged (int cubeId, const Isis::Brick *data) |
This is called when a brick is written. | |
Signals | |
void | RequestReadCube (int cubeId, int startSample, int startLine, int endSample, int endLine, int band, void *caller) |
Ask for a brick for reading. | |
void | RequestReadWriteCube (int cubeId, int startSample, int startLine, int endSample, int endLine, int band, void *caller) |
Ask for a brick for reading and writing. | |
void | NotifyDoneWithData (int, const Isis::Brick *) |
Let the cube data thread know we're no longer working with a particular brick. | |
Public Member Functions | |
CubeDataThreadTester (CubeDataThread *) | |
This initializes a CubeDataThreadTester. | |
virtual | ~CubeDataThreadTester () |
This cleans up the cube data thread. | |
int | NumberOfTestsDone () |
Returns the number of tests done (testing methods count as several) | |
CubeDataThread * | DataThread () |
Returns the cube data thread being tested. | |
void | Connect () |
This connects this class' signals and slots with CubeDataThread's signals and slots. | |
void | ReadCubeTest (int) |
This tests a basic read. | |
void | ReadCubeTest2 (int, int) |
This tests two basic reads with no conflicts. | |
void | ReadCubeTest3 (int) |
This tests an overlapping read. | |
void | WriteCubeTest (int) |
This tests a basic write. | |
void | WriteCubeTest2 (int, int) |
This tests two non-conflicting writes. | |
void | WriteCubeTest3 (int) |
This tests two conflicting* writes. | |
void | WriteCubeTest3BreakDeadlock () |
This test breaks the deadlock caused by the third write test. | |
void | NotifyChangeTest (int) |
This test tests this automatic change notifications. | |
Private Member Functions | |
void | run () |
This thread is centered completely around its event loop. | |
Private Attributes | |
int | p_numTestsDone |
The count of completed tests. | |
CubeDataThread * | p_cubeDataThread |
The data thread being tested. | |
bool | p_execStarted |
True if this thread is started. | |
bool | p_notifyDone |
True if we will notify done on the next brick received for R/W. | |
QVector< QPair< int, const Isis::Brick * > > * | p_cachedDoneBricks |
A list of bricks we haven't send the done signal for. | |
Definition at line 25 of file CubeDataThreadTester.h.
Isis::CubeDataThreadTester::CubeDataThreadTester | ( | CubeDataThread * | testObject | ) |
This initializes a CubeDataThreadTester.
The CubeDataThread given is the subject of the tests.
testObject | The CubeDataThread instance to be tested |
Definition at line 33 of file CubeDataThreadTester.cpp.
References p_cachedDoneBricks, p_cubeDataThread, p_execStarted, p_notifyDone, and p_numTestsDone.
|
virtual |
This cleans up the cube data thread.
Definition at line 78 of file CubeDataThreadTester.cpp.
References p_execStarted.
|
slot |
This is called when a brick is written.
Definition at line 360 of file CubeDataThreadTester.cpp.
References Isis::Buffer::at(), NotifyDoneWithData(), p_numTestsDone, and Isis::Buffer::size().
Referenced by NotifyChangeTest().
void Isis::CubeDataThreadTester::Connect | ( | ) |
This connects this class' signals and slots with CubeDataThread's signals and slots.
Definition at line 52 of file CubeDataThreadTester.cpp.
References NotifyDoneWithData(), p_cubeDataThread, ReadBrick(), ReadWriteBrick(), RequestReadCube(), and RequestReadWriteCube().
|
inline |
Returns the cube data thread being tested.
Definition at line 38 of file CubeDataThreadTester.h.
References p_cubeDataThread.
void Isis::CubeDataThreadTester::NotifyChangeTest | ( | int | cubeId | ) |
This test tests this automatic change notifications.
This performs 2 tests.
cubeId | The identifier given by the data thread for the file to test |
Definition at line 206 of file CubeDataThreadTester.cpp.
References Isis::CubeDataThread::AddChangeListener(), BrickChanged(), p_cubeDataThread, and RequestReadWriteCube().
|
signal |
Let the cube data thread know we're no longer working with a particular brick.
Referenced by BrickChanged(), Connect(), ReadBrick(), ReadWriteBrick(), and WriteCubeTest3BreakDeadlock().
|
inline |
Returns the number of tests done (testing methods count as several)
Definition at line 33 of file CubeDataThreadTester.h.
References p_numTestsDone.
|
slot |
This is called when a brick is read.
Definition at line 228 of file CubeDataThreadTester.cpp.
References Isis::Buffer::at(), NotifyDoneWithData(), p_cachedDoneBricks, p_notifyDone, p_numTestsDone, and Isis::Buffer::size().
Referenced by Connect().
void Isis::CubeDataThreadTester::ReadCubeTest | ( | int | cubeId | ) |
This tests a basic read.
This performs 1 test.
cubeId | The identifier given by the data thread for the file to test |
Definition at line 99 of file CubeDataThreadTester.cpp.
References RequestReadCube().
void Isis::CubeDataThreadTester::ReadCubeTest2 | ( | int | cubeId1, |
int | cubeId2 ) |
This tests two basic reads with no conflicts.
This performs 2 tests.
Definition at line 111 of file CubeDataThreadTester.cpp.
References p_notifyDone, and RequestReadCube().
void Isis::CubeDataThreadTester::ReadCubeTest3 | ( | int | cubeId | ) |
This tests an overlapping read.
This performs 2 tests.
cubeId | The identifier given by the data thread for the file to test |
Definition at line 126 of file CubeDataThreadTester.cpp.
References p_notifyDone, and RequestReadCube().
|
slot |
This is called when a brick is given for R/W.
Definition at line 283 of file CubeDataThreadTester.cpp.
References Isis::Buffer::at(), NotifyDoneWithData(), p_cachedDoneBricks, p_notifyDone, p_numTestsDone, and Isis::Buffer::size().
Referenced by Connect().
|
signal |
Ask for a brick for reading.
cubeId | Cube identifier |
startSample | Brick starting sample |
startLine | Brick starting line |
endSample | Brick ending sample |
endLine | Brick ending line |
band | Brick band |
caller | A this pointer |
Referenced by Connect(), ReadCubeTest(), ReadCubeTest2(), ReadCubeTest3(), and WriteCubeTest().
|
signal |
Ask for a brick for reading and writing.
cubeId | Cube identifier |
startSample | Brick starting sample |
startLine | Brick starting line |
endSample | Brick ending sample |
endLine | Brick ending line |
band | Brick band |
caller | A this pointer |
Referenced by Connect(), NotifyChangeTest(), WriteCubeTest(), WriteCubeTest2(), and WriteCubeTest3().
|
private |
This thread is centered completely around its event loop.
returns the cube id
Definition at line 89 of file CubeDataThreadTester.cpp.
References p_execStarted.
void Isis::CubeDataThreadTester::WriteCubeTest | ( | int | cubeId | ) |
This tests a basic write.
This performs 2 tests.
cubeId | The identifier given by the data thread for the file to test |
Definition at line 141 of file CubeDataThreadTester.cpp.
References RequestReadCube(), and RequestReadWriteCube().
void Isis::CubeDataThreadTester::WriteCubeTest2 | ( | int | cubeId1, |
int | cubeId2 ) |
This tests two non-conflicting writes.
This performs 2 tests.
Definition at line 154 of file CubeDataThreadTester.cpp.
References p_notifyDone, and RequestReadWriteCube().
void Isis::CubeDataThreadTester::WriteCubeTest3 | ( | int | cubeId | ) |
This tests two conflicting* writes.
This causes a deadlock!
This performs a test, deadlocks, and once the deadlock is broken (via WriteCubeTest3BreakDeadlock), finishes another test.
cubeId | The identifier given by the data thread for the file to test |
Definition at line 172 of file CubeDataThreadTester.cpp.
References p_notifyDone, and RequestReadWriteCube().
void Isis::CubeDataThreadTester::WriteCubeTest3BreakDeadlock | ( | ) |
This test breaks the deadlock caused by the third write test.
Definition at line 186 of file CubeDataThreadTester.cpp.
References NotifyDoneWithData(), and p_cachedDoneBricks.
|
private |
A list of bricks we haven't send the done signal for.
Definition at line 111 of file CubeDataThreadTester.h.
Referenced by CubeDataThreadTester(), ReadBrick(), ReadWriteBrick(), and WriteCubeTest3BreakDeadlock().
|
private |
The data thread being tested.
Definition at line 102 of file CubeDataThreadTester.h.
Referenced by Connect(), CubeDataThreadTester(), DataThread(), and NotifyChangeTest().
|
private |
True if this thread is started.
Definition at line 105 of file CubeDataThreadTester.h.
Referenced by CubeDataThreadTester(), run(), and ~CubeDataThreadTester().
|
private |
True if we will notify done on the next brick received for R/W.
Definition at line 108 of file CubeDataThreadTester.h.
Referenced by CubeDataThreadTester(), ReadBrick(), ReadCubeTest2(), ReadCubeTest3(), ReadWriteBrick(), WriteCubeTest2(), and WriteCubeTest3().
|
private |
The count of completed tests.
Definition at line 99 of file CubeDataThreadTester.h.
Referenced by BrickChanged(), CubeDataThreadTester(), NumberOfTestsDone(), ReadBrick(), and ReadWriteBrick().