| 
									
										
										
										
											2009-01-08 17:41:38 -05:00
										 |  |  | ! Copyright (C) 2008 Slava Pestov, Doug Coleman. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  | USING: concurrency.combinators db.pools db.sqlite db.tuples | 
					
						
							|  |  |  | db.types kernel math random threads tools.test db sequences | 
					
						
							| 
									
										
										
										
											2009-05-15 00:23:06 -04:00
										 |  |  | io prettyprint db.postgresql accessors io.files.temp | 
					
						
							| 
									
										
										
										
											2009-04-20 22:32:23 -04:00
										 |  |  | namespaces fry system math.parser ;
 | 
					
						
							| 
									
										
										
										
											2009-01-08 17:41:38 -05:00
										 |  |  | IN: db.tester | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-21 22:22:51 -05:00
										 |  |  | : postgresql-test-db ( -- postgresql-db )
 | 
					
						
							|  |  |  |     <postgresql-db> | 
					
						
							|  |  |  |         "localhost" >>host | 
					
						
							|  |  |  |         "postgres" >>username | 
					
						
							|  |  |  |         "thepasswordistrust" >>password | 
					
						
							|  |  |  |         "factor-test" >>database ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : sqlite-test-db ( -- sqlite-db )
 | 
					
						
							|  |  |  |     "tuples-test.db" temp-file <sqlite-db> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! These words leak resources, but are useful for interactivel testing | 
					
						
							|  |  |  | : set-sqlite-db ( -- )
 | 
					
						
							|  |  |  |     sqlite-db db-open db-connection set ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : set-postgresql-db ( -- )
 | 
					
						
							|  |  |  |     postgresql-db db-open db-connection set ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : test-sqlite ( quot -- )
 | 
					
						
							|  |  |  |     '[ | 
					
						
							|  |  |  |         [ ] [ sqlite-test-db _ with-db ] unit-test | 
					
						
							|  |  |  |     ] call ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : test-postgresql ( quot -- )
 | 
					
						
							|  |  |  |     '[ | 
					
						
							|  |  |  |         os windows? cpu x86.64? and [ | 
					
						
							|  |  |  |             [ ] [ postgresql-test-db _ with-db ] unit-test | 
					
						
							|  |  |  |         ] unless
 | 
					
						
							|  |  |  |     ] call ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-08 17:41:38 -05:00
										 |  |  | TUPLE: test-1 id a b c ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test-1 "TEST1" { | 
					
						
							|  |  |  |    { "id" "ID" INTEGER +db-assigned-id+ } | 
					
						
							|  |  |  |    { "a" "A" { VARCHAR 256 } +not-null+ } | 
					
						
							|  |  |  |    { "b" "B" { VARCHAR 256 } +not-null+ } | 
					
						
							|  |  |  |    { "c" "C" { VARCHAR 256 } +not-null+ } | 
					
						
							|  |  |  | } define-persistent | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: test-2 id x y z ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test-2 "TEST2" { | 
					
						
							|  |  |  |    { "id" "ID" INTEGER +db-assigned-id+ } | 
					
						
							|  |  |  |    { "x" "X" { VARCHAR 256 } +not-null+ } | 
					
						
							|  |  |  |    { "y" "Y" { VARCHAR 256 } +not-null+ } | 
					
						
							|  |  |  |    { "z" "Z" { VARCHAR 256 } +not-null+ } | 
					
						
							|  |  |  | } define-persistent | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-20 22:47:16 -04:00
										 |  |  | : test-1-tuple ( -- tuple )
 | 
					
						
							|  |  |  |     f 100 random 100 random 100 random [ number>string ] tri@
 | 
					
						
							|  |  |  |     test-1 boa ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-08 17:41:38 -05:00
										 |  |  | : db-tester ( test-db -- )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             test-1 ensure-table | 
					
						
							|  |  |  |             test-2 ensure-table | 
					
						
							|  |  |  |         ] with-db | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         10 [ | 
					
						
							|  |  |  |             drop
 | 
					
						
							|  |  |  |             10 [ | 
					
						
							|  |  |  |                 dup [ | 
					
						
							| 
									
										
										
										
											2009-04-20 22:47:16 -04:00
										 |  |  |                     test-1-tuple insert-tuple yield | 
					
						
							| 
									
										
										
										
											2009-01-08 17:41:38 -05:00
										 |  |  |                 ] with-db | 
					
						
							|  |  |  |             ] times
 | 
					
						
							|  |  |  |         ] with parallel-each | 
					
						
							|  |  |  |     ] bi ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : db-tester2 ( test-db -- )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         [ | 
					
						
							| 
									
										
										
										
											2009-01-11 22:07:39 -05:00
										 |  |  |             test-1 ensure-table | 
					
						
							|  |  |  |             test-2 ensure-table | 
					
						
							|  |  |  |         ] with-db | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         <db-pool> [ | 
					
						
							|  |  |  |             10 [ | 
					
						
							|  |  |  |                 10 [ | 
					
						
							| 
									
										
										
										
											2009-04-20 22:47:16 -04:00
										 |  |  |                     test-1-tuple insert-tuple yield | 
					
						
							| 
									
										
										
										
											2009-01-11 22:07:39 -05:00
										 |  |  |                 ] times
 | 
					
						
							| 
									
										
										
										
											2009-01-08 17:41:38 -05:00
										 |  |  |             ] parallel-each | 
					
						
							| 
									
										
										
										
											2009-01-11 22:07:39 -05:00
										 |  |  |         ] with-pooled-db | 
					
						
							| 
									
										
										
										
											2009-01-08 17:41:38 -05:00
										 |  |  |     ] bi ;
 |