refactored test suite
This commit is contained in:
parent
7a0d08ae50
commit
4ad8e8d528
30
schema.t.out
Normal file
30
schema.t.out
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
ID: credit promise debt
|
||||||
|
--------------------------------
|
||||||
|
Club: 0 +7200 -23450
|
||||||
|
john: 7200 +0 -7200
|
||||||
|
# Reflect john paying its bills all at once ...
|
||||||
|
Club: 7200 +0 -23450
|
||||||
|
john: 0 +0 0
|
||||||
|
# Charge Club with server hosting provided by alex ...
|
||||||
|
Club: 0 +0 -16250
|
||||||
|
alex: 7200 +16250 0
|
||||||
|
# Some updates and deletes that could, unless denied, destroy consistency ...
|
||||||
|
Error: near line 274: paid is set and adjusted automatically according to added Transfer records
|
||||||
|
Error: near line 275: Debt is involved in transfers to revoke at first
|
||||||
|
Error: near line 276: FOREIGN KEY constraint failed
|
||||||
|
# After revoking transactions, you are free to change or delete debts and credits ...
|
||||||
|
Club: 7200 +0 0
|
||||||
|
alex: 0 +0 0
|
||||||
|
# But let's rollback that what-if excurse. This is how it currently is ...
|
||||||
|
Club: 0 +0 -16250
|
||||||
|
alex: 7200 +16250 0
|
||||||
|
###################################################################
|
||||||
|
# Now it is your turn: Study the sql code yielding the output above
|
||||||
|
# then enter new members and let them pay the fees.
|
||||||
|
# (PLUS: Let have one discalculia and pay too little or too much.)
|
||||||
|
# Once the club has enough money to pay alex' hosting service,
|
||||||
|
# update (i.e. revoke and reenter) the respective transaction.
|
||||||
|
# Finally issue a bank transfer to alex. Hint: An outgoing transfer
|
||||||
|
# is simply a debt charging alex' own virtual account and without
|
||||||
|
# targetCredit (NULL). PLUS: What happens if the description of
|
||||||
|
# the bank transfer does not contain any or only a wrong IBAN?
|
54
schema.t.sql
54
schema.t.sql
@ -1,5 +1,7 @@
|
|||||||
PRAGMA foreign_keys = ON;
|
PRAGMA foreign_keys = ON;
|
||||||
|
|
||||||
|
-- To understand the sql below, see the schema.sql file.
|
||||||
|
|
||||||
INSERT INTO Account VALUES ("Club", "eV", 1, NULL), ("john", "Member", 44, NULL), ("alex", "Member", 6, "DE1234567890123456");
|
INSERT INTO Account VALUES ("Club", "eV", 1, NULL), ("john", "Member", 44, NULL), ("alex", "Member", 6, "DE1234567890123456");
|
||||||
|
|
||||||
INSERT INTO Credit VALUES (1, "Club", "2016-01-01", "Membership fees May 2016 until incl. April 2017", 0, 0),
|
INSERT INTO Credit VALUES (1, "Club", "2016-01-01", "Membership fees May 2016 until incl. April 2017", 0, 0),
|
||||||
@ -20,19 +22,43 @@ INSERT INTO Debit VALUES ("MB1605-john", "john", 1, "2016-05-01", "Membership fe
|
|||||||
("MB1704-john", "john", 1, "2016-05-01", "Membership fee April 2017", 600, 0),
|
("MB1704-john", "john", 1, "2016-05-01", "Membership fee April 2017", 600, 0),
|
||||||
("TWX2016/123", "Club", 3, "2016-01-15", "Server Hosting 2016", 23450, 0);
|
("TWX2016/123", "Club", 3, "2016-01-15", "Server Hosting 2016", 23450, 0);
|
||||||
|
|
||||||
.separator " "
|
.separator " "
|
||||||
SELECT "Balance of " || ID || "'s account:", credit, debit * -1 FROM Balance WHERE ID in ("john", "Club");
|
SELECT "ID: credit promise debt";
|
||||||
INSERT INTO Transfer (receiptId, fromCredit) VALUES ("MB1605-john", 2), ("MB1606-john", 2), ("MB1607-john", 2), ("MB1608-john", 2), ("MB1609-john", 2), ("MB1610-john", 2), ("MB1611-john", 2), ("MB1612-john", 2), ("MB1701-john", 2), ("MB1702-john", 2), ("MB1703-john", 2), ("MB1704-john", 2);
|
SELECT "--------------------------------";
|
||||||
SELECT "Balance of " || ID || "'s account:", credit, debit * -1 FROM Balance WHERE ID in ("john", "Club");
|
|
||||||
INSERT INTO Transfer (receiptId, fromCredit) VALUES ("TWX2016/123", 1);
|
SELECT ID || ":", credit, '+' || promised, debt * -1 FROM Balance WHERE ID in ("john", "Club");
|
||||||
SELECT "Balance of " || ID || "'s Account:", credit, debit * -1 FROM Balance WHERE ID in ("Club", "alex");
|
|
||||||
UPDATE Debit SET paid = 20000 WHERE receiptId="TWX2016/123";
|
SELECT "# Reflect john paying its bills all at once ...";
|
||||||
UPDATE Debit SET value = 20000 WHERE receiptId="TWX2016/123";
|
INSERT INTO Transfer (billId, fromCredit) VALUES ("MB1605-john", 2), ("MB1606-john", 2), ("MB1607-john", 2), ("MB1608-john", 2), ("MB1609-john", 2), ("MB1610-john", 2), ("MB1611-john", 2), ("MB1612-john", 2), ("MB1701-john", 2), ("MB1702-john", 2), ("MB1703-john", 2), ("MB1704-john", 2);
|
||||||
DELETE FROM Debit WHERE receiptId="TWX2016/123"; -- *SHOULD NOT* work
|
SELECT ID || ":", credit, '+' || promised, debt * -1 FROM Balance WHERE ID in ("john", "Club");
|
||||||
|
|
||||||
|
SELECT "# Charge Club with server hosting provided by alex ...";
|
||||||
|
INSERT INTO Transfer (billId, fromCredit) VALUES ("TWX2016/123", 1);
|
||||||
|
SELECT ID || ":", credit, '+' || promised, debt * -1 FROM Balance WHERE ID in ("Club", "alex");
|
||||||
|
|
||||||
|
SELECT "# Some updates and deletes that could, unless denied, destroy consistency ...";
|
||||||
|
UPDATE Debit SET paid = 20000 WHERE billId="TWX2016/123";
|
||||||
|
UPDATE Debit SET value = 20000 WHERE billId="TWX2016/123";
|
||||||
|
DELETE FROM Debit WHERE billId="TWX2016/123"; -- *SHOULD NOT* work
|
||||||
|
|
||||||
|
SELECT "# After revoking transactions, you are free to change or delete debts and credits ...";
|
||||||
BEGIN TRANSACTION;
|
BEGIN TRANSACTION;
|
||||||
DELETE FROM Transfer WHERE receiptId="TWX2016/123";
|
DELETE FROM Transfer WHERE billId="TWX2016/123";
|
||||||
UPDATE Debit SET value = 20000 WHERE receiptId="TWX2016/123";
|
UPDATE Debit SET value = 20000 WHERE billId="TWX2016/123";
|
||||||
DELETE FROM Debit WHERE receiptId="TWX2016/123"; -- *SHOULD* work
|
DELETE FROM Debit WHERE billId="TWX2016/123"; -- *SHOULD* work
|
||||||
SELECT "Balance of " || ID || "'s Account:", credit, debit * -1 FROM Balance WHERE ID in ("Club", "alex");
|
SELECT ID || ":", credit, '+' || promised, debt * -1 FROM Balance WHERE ID in ("Club", "alex");
|
||||||
ROLLBACK TRANSACTION;
|
ROLLBACK TRANSACTION;
|
||||||
SELECT "Balance of " || ID || "'s Account:", credit, debit * -1 FROM Balance WHERE ID in ("Club", "alex");
|
|
||||||
|
SELECT '# But let''s rollback that what-if excurse. This is how it currently is ...';
|
||||||
|
SELECT ID || ":", credit, '+' || promised, debt * -1 FROM Balance WHERE ID in ("Club", "alex");
|
||||||
|
|
||||||
|
SELECT '###################################################################';
|
||||||
|
SELECT '# Now it is your turn: Study the sql code yielding the output above';
|
||||||
|
SELECT '# then enter new members and let them pay the fees.';
|
||||||
|
SELECT '# (PLUS: Let have one discalculia and pay too little or too much.)';
|
||||||
|
SELECT '# Once the club has enough money to pay alex'' hosting service,';
|
||||||
|
SELECT '# update (i.e. revoke and reenter) the respective transaction.';
|
||||||
|
SELECT '# Finally issue a bank transfer to alex. Hint: An outgoing transfer';
|
||||||
|
SELECT '# is simply a debt charging alex'' own virtual account and without';
|
||||||
|
SELECT '# targetCredit (NULL). PLUS: What happens if the description of';
|
||||||
|
SELECT '# the bank transfer does not contain any or only a wrong IBAN?';
|
||||||
|
Loading…
Reference in New Issue
Block a user