summaryrefslogtreecommitdiff
path: root/caching-tests
diff options
context:
space:
mode:
authorGravatar Ziv Scully <ziv@mit.edu>2014-05-27 21:14:13 -0400
committerGravatar Ziv Scully <ziv@mit.edu>2014-05-27 21:14:13 -0400
commitb1516ed386ca303a526959586f0a06564ca77bb0 (patch)
treed37d80752e5a132615064d4b1e991dcb8ef35793 /caching-tests
parent93d6de491838eb3607a12686bfdc250366aa60e4 (diff)
Finishes initial prototype, caching parameterless pages with table-match-based invalidation. Still has problems parsing non-Postgres SQL dialects properly.
Diffstat (limited to 'caching-tests')
-rw-r--r--caching-tests/test.dbbin0 -> 3072 bytes
-rw-r--r--caching-tests/test.sql11
-rw-r--r--caching-tests/test.ur112
-rw-r--r--caching-tests/test.urp3
4 files changed, 55 insertions, 71 deletions
diff --git a/caching-tests/test.db b/caching-tests/test.db
new file mode 100644
index 00000000..190d2868
--- /dev/null
+++ b/caching-tests/test.db
Binary files differ
diff --git a/caching-tests/test.sql b/caching-tests/test.sql
new file mode 100644
index 00000000..862245b7
--- /dev/null
+++ b/caching-tests/test.sql
@@ -0,0 +1,11 @@
+CREATE TABLE uw_Test_foo01(uw_id integer NOT NULL, uw_bar text NOT NULL,
+ PRIMARY KEY (uw_id)
+
+ );
+
+ CREATE TABLE uw_Test_foo10(uw_id integer NOT NULL, uw_bar text NOT NULL,
+ PRIMARY KEY (uw_id)
+
+ );
+
+ \ No newline at end of file
diff --git a/caching-tests/test.ur b/caching-tests/test.ur
index 4703e229..d13379a8 100644
--- a/caching-tests/test.ur
+++ b/caching-tests/test.ur
@@ -1,81 +1,53 @@
table foo01 : {Id : int, Bar : string} PRIMARY KEY Id
table foo10 : {Id : int, Bar : string} PRIMARY KEY Id
-(* val query = (SELECT * FROM foo WHERE foo.Bar = "baz") *)
-(* val insert = (INSERT INTO foo (Id, Bar) VALUES (42, "baz")) *)
+fun flush01 () : transaction page =
+ dml (INSERT INTO foo01 (Id, Bar) VALUES (42, "baz01"));
+ dml (UPDATE foo01 SET Bar = "baz01" WHERE Id = 42);
+ return <xml><body>
+ Flushed 1!
+ </body></xml>
-fun flush01 () : transaction page=
- dml (INSERT INTO foo01 (Id, Bar) VALUES (42, "baz"));
- return
- <xml>
- <body>
- Flushed 1!
- </body>
- </xml>
+fun flush10 () : transaction page =
+ dml (UPDATE foo10 SET Bar = "baz10" WHERE Id = 42);
+ return <xml><body>
+ Flushed 2!
+ </body></xml>
-fun flush10 () : transaction page=
- dml (INSERT INTO foo10 (Id, Bar) VALUES (42, "baz"));
- return
- <xml>
- <body>
- Flushed 2!
- </body>
- </xml>
-
-fun flush11 () : transaction page=
- dml (INSERT INTO foo01 (Id, Bar) VALUES (42, "baz"));
- dml (INSERT INTO foo10 (Id, Bar) VALUES (42, "baz"));
- return
- <xml>
- <body>
- Flushed 1 and 2!
- </body>
- </xml>
+fun flush11 () : transaction page =
+ dml (UPDATE foo01 SET Bar = "baz11" WHERE Id = 42);
+ dml (UPDATE foo10 SET Bar = "baz11" WHERE Id = 42);
+ return <xml><body>
+ Flushed 1 and 2!
+ </body></xml>
fun cache01 () : transaction page =
- res <- oneOrNoRows (SELECT foo01.Id, foo01.Bar
- FROM foo01
- WHERE foo01.Bar = "baz");
- return
- <xml>
- <body>
- Reading 1.
- {case res of
- None => <xml></xml>
- | Some row => <xml>{[row.Foo01.Bar]}</xml>}
- </body>
- </xml>
+ res <- oneOrNoRows (SELECT foo01.Bar FROM foo01 WHERE foo01.Id = 42);
+ return <xml><body>
+ Reading 1.
+ {case res of
+ None => <xml></xml>
+ | Some row => <xml>{[row.Foo01.Bar]}</xml>}
+ </body></xml>
fun cache10 () : transaction page =
- res <- oneOrNoRows (SELECT foo10.Id, foo10.Bar
- FROM foo10
- WHERE foo10.Bar = "baz");
- return
- <xml>
- <body>
- Reading 2.
- {case res of
- None => <xml></xml>
- | Some row => <xml>{[row.Foo10.Bar]}</xml>}
- </body>
- </xml>
+ res <- oneOrNoRows (SELECT foo10.Bar FROM foo10 WHERE foo10.Id = 42);
+ return <xml><body>
+ Reading 2.
+ {case res of
+ None => <xml></xml>
+ | Some row => <xml>{[row.Foo10.Bar]}</xml>}
+ </body></xml>
fun cache11 () : transaction page =
- res <- oneOrNoRows (SELECT foo01.Id, foo01.Bar
- FROM foo01
- WHERE foo01.Bar = "baz");
- bla <- oneOrNoRows (SELECT foo10.Id, foo10.Bar
- FROM foo10
- WHERE foo10.Bar = "baz");
- return
- <xml>
- <body>
- Reading 1 and 2.
- {case res of
- None => <xml></xml>
- | Some row => <xml>{[row.Foo01.Bar]}</xml>}
- {case bla of
- None => <xml></xml>
- | Some row => <xml>{[row.Foo10.Bar]}</xml>}
- </body>
- </xml>
+ res <- oneOrNoRows (SELECT foo01.Bar FROM foo01 WHERE foo01.Id = 42);
+ bla <- oneOrNoRows (SELECT foo10.Bar FROM foo10 WHERE foo10.Id = 42);
+ return <xml><body>
+ Reading 1 and 2.
+ {case res of
+ None => <xml></xml>
+ | Some row => <xml>{[row.Foo01.Bar]}</xml>}
+ {case bla of
+ None => <xml></xml>
+ | Some row => <xml>{[row.Foo10.Bar]}</xml>}
+ </body></xml>
diff --git a/caching-tests/test.urp b/caching-tests/test.urp
index e5111220..123f58e5 100644
--- a/caching-tests/test.urp
+++ b/caching-tests/test.urp
@@ -1,4 +1,5 @@
-database dbname=test
+database test.db
+sql test.sql
safeGet Test/flush01
safeGet Test/flush10
safeGet Test/flush11