mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-08-02 14:38:34 +02:00
- Added all source code.
This commit is contained in:
parent
7f8fc1182d
commit
b5be083d88
27 changed files with 7842 additions and 0 deletions
5
src/tests/.gitignore
vendored
Normal file
5
src/tests/.gitignore
vendored
Normal file
|
@ -0,0 +1,5 @@
|
|||
t.t
|
||||
tdb.t
|
||||
pending.data
|
||||
completed.data
|
||||
|
24
src/tests/Makefile
Normal file
24
src/tests/Makefile
Normal file
|
@ -0,0 +1,24 @@
|
|||
PROJECT = t.t tdb.t
|
||||
CFLAGS = -I.. -I../../../library/include -Wall -pedantic -ggdb3 -fno-rtti
|
||||
LFLAGS = -L/usr/local/lib -L../../../library/lib -lcompany -lpcre -lncurses -lcurl
|
||||
|
||||
all: $(PROJECT)
|
||||
|
||||
install: $(PROJECT)
|
||||
@echo unimplemented
|
||||
|
||||
test: $(PROJECT)
|
||||
@echo unimplemented
|
||||
|
||||
clean:
|
||||
-rm *.o $(PROJECT)
|
||||
|
||||
.cpp.o:
|
||||
g++ -c $(CFLAGS) $<
|
||||
|
||||
t.t: t.t.o ../T.o ../parse.o ../../../library/lib/libcompany.a
|
||||
g++ t.t.o ../T.o ../parse.o $(LFLAGS) -o t.t
|
||||
|
||||
tdb.t: tdb.t.o ../TDB.o ../T.o ../parse.o ../../../library/lib/libcompany.a
|
||||
g++ tdb.t.o ../TDB.o ../T.o ../parse.o $(LFLAGS) -o tdb.t
|
||||
|
37
src/tests/t.t.cpp
Normal file
37
src/tests/t.t.cpp
Normal file
|
@ -0,0 +1,37 @@
|
|||
////////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
#include <T.h>
|
||||
#include <library.h>
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
int main (int argc, char** argv)
|
||||
{
|
||||
plan (4);
|
||||
|
||||
T t;
|
||||
std::string s = t.compose ();
|
||||
is ((int)s.length (), 46, "T::T (); T::compose ()");
|
||||
diag (s);
|
||||
|
||||
t.setStatus (T::completed);
|
||||
s = t.compose ();
|
||||
is (s[37], '+', "T::setStatus (completed)");
|
||||
diag (s);
|
||||
|
||||
t.setStatus (T::deleted);
|
||||
s = t.compose ();
|
||||
is (s[37], 'X', "T::setStatus (deleted)");
|
||||
diag (s);
|
||||
|
||||
// Round trip test.
|
||||
std::string sample = "00000000-0000-0000-0000-000000000000 - [] [] Sample";
|
||||
T t2;
|
||||
t2.parse (sample);
|
||||
sample += "\n";
|
||||
is (t2.compose (), sample, "T::parse -> T::compose round trip");
|
||||
return 0;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
|
127
src/tests/tdb.t.cpp
Normal file
127
src/tests/tdb.t.cpp
Normal file
|
@ -0,0 +1,127 @@
|
|||
////////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
#include <iostream>
|
||||
#include <unistd.h>
|
||||
|
||||
#include <TDB.h>
|
||||
#include <library.h>
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
int main (int argc, char** argv)
|
||||
{
|
||||
plan (43);
|
||||
|
||||
try
|
||||
{
|
||||
// Remove any residual test file.
|
||||
unlink ("./pending.data");
|
||||
unlink ("./completed.data");
|
||||
|
||||
// Try reading an empty database.
|
||||
TDB tdb;
|
||||
tdb.dataDirectory (".");
|
||||
std::vector <T> all;
|
||||
ok (!tdb.pendingT (all), "TDB::pendingT read empty db");
|
||||
is ((int) all.size (), 0, "empty db");
|
||||
ok (!tdb.allPendingT (all), "TDB::allPendingT read empty db");
|
||||
is ((int) all.size (), 0, "empty db");
|
||||
ok (!tdb.completedT (all), "TDB::completedT read empty db");
|
||||
is ((int) all.size (), 0, "empty db");
|
||||
ok (!tdb.allCompletedT (all), "TDB::allCompletedT read empty db");
|
||||
is ((int) all.size (), 0, "empty db");
|
||||
|
||||
// Add a new task.
|
||||
T t1;
|
||||
t1.setId (1);
|
||||
t1.setStatus (T::pending);
|
||||
t1.setAttribute ("project", "p1");
|
||||
t1.setDescription ("task 1");
|
||||
diag (t1.compose ());
|
||||
ok (tdb.addT (t1), "TDB::addT t1");
|
||||
|
||||
// Verify as above.
|
||||
ok (tdb.pendingT (all), "TDB::pendingT read db");
|
||||
is ((int) all.size (), 1, "empty db");
|
||||
ok (tdb.allPendingT (all), "TDB::allPendingT read db");
|
||||
is ((int) all.size (), 1, "empty db");
|
||||
ok (!tdb.completedT (all), "TDB::completedT read empty db");
|
||||
is ((int) all.size (), 0, "empty db");
|
||||
ok (!tdb.allCompletedT (all), "TDB::allCompletedT read empty db");
|
||||
is ((int) all.size (), 0, "empty db");
|
||||
|
||||
// TODO Modify task.
|
||||
fail ("modify");
|
||||
fail ("verify");
|
||||
|
||||
// Complete task.
|
||||
ok (tdb.completeT (t1), "TDB::completeT t1");;
|
||||
ok (!tdb.pendingT (all), "TDB::pendingT read db");
|
||||
is ((int) all.size (), 0, "empty db");
|
||||
ok (tdb.allPendingT (all), "TDB::allPendingT read db");
|
||||
is ((int) all.size (), 1, "empty db");
|
||||
ok (!tdb.completedT (all), "TDB::completedT read empty db");
|
||||
is ((int) all.size (), 0, "empty db");
|
||||
ok (!tdb.allCompletedT (all), "TDB::allCompletedT read empty db");
|
||||
is ((int) all.size (), 0, "empty db");
|
||||
|
||||
is (tdb.gc (), 1, "TDB::gc");
|
||||
ok (!tdb.pendingT (all), "TDB::pendingT read empty db");
|
||||
is ((int) all.size (), 0, "empty db");
|
||||
ok (!tdb.allPendingT (all), "TDB::allPendingT read empty db");
|
||||
is ((int) all.size (), 0, "empty db");
|
||||
ok (tdb.completedT (all), "TDB::completedT read db");
|
||||
is ((int) all.size (), 1, "empty db");
|
||||
ok (tdb.allCompletedT (all), "TDB::allCompletedT read db");
|
||||
is ((int) all.size (), 1, "empty db");
|
||||
|
||||
// Add a new task.
|
||||
T t2;
|
||||
t2.setId (2);
|
||||
t2.setAttribute ("project", "p2");
|
||||
t2.setDescription ("task 2");
|
||||
diag (t2.compose ());
|
||||
ok (tdb.addT (t2), "TDB::addT t2");
|
||||
|
||||
fail ("verify");
|
||||
|
||||
// Delete task.
|
||||
ok (tdb.deleteT (t2), "TDB::deleteT t2");
|
||||
|
||||
fail ("verify");
|
||||
|
||||
// GC the files.
|
||||
is (tdb.gc (), 1, "1 <- TDB::gc");
|
||||
|
||||
// Read log file.
|
||||
std::vector <std::string> entries;
|
||||
tdb.logRead (entries);
|
||||
std::vector <std::string>::iterator it;
|
||||
for (it = entries.begin (); it != entries.end (); ++it)
|
||||
diag (*it);
|
||||
|
||||
// TODO Verify contents of above transactions.
|
||||
fail ("verify");
|
||||
}
|
||||
|
||||
catch (std::string& error)
|
||||
{
|
||||
diag (error);
|
||||
return -1;
|
||||
}
|
||||
|
||||
catch (...)
|
||||
{
|
||||
diag ("Unknown error.");
|
||||
return -2;
|
||||
}
|
||||
|
||||
/*
|
||||
unlink ("./pending.data");
|
||||
unlink ("./completed.data");
|
||||
*/
|
||||
return 0;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue