Megatest

Changes On Branch 7102506f8d436175
Login

Changes In Branch v1.60-db-refactor Excluding Merge-Ins

This is equivalent to a diff from 22daf8e282 to 7102506f8d

2015-12-03
22:46
Initial version of spublish check-in: 5f3d099673 user: matt tags: v1.60
2015-11-26
21:59
db refactor Closed-Leaf check-in: 7102506f8d user: matt tags: v1.60-db-refactor
2015-11-16
13:00
First pass at processing sections on the fly check-in: 22daf8e282 user: mrwellan tags: v1.60
2015-11-12
14:11
Be more lazy on running sync to megatest.db check-in: 27552d9089 user: mrwellan tags: v1.60

Modified db.scm from [725b61e04a] to [cd97844a09].

298
299
300
301
302
303
304

305

306
307
308
309
310
311
312
313


314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350







































351
352
353
354
355
356
357
298
299
300
301
302
303
304
305

306
307
308
309
310
311
312
313
314
315
316





































317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362







+
-
+








+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+







    (if (and dbexists (not write-access))
	(set! *db-write-access* #f))
    (cons db dbpath)))

;; sync run to disk if touched
;;
(define (db:sync-touched dbstruct run-id #!key (force-sync #f))
  (let ((local  (dbr:dbstruct-get-local dbstruct))
  (let ((mtime  (dbr:dbstruct-get-mtime dbstruct))
	(mtime  (dbr:dbstruct-get-mtime dbstruct))
	(stime  (dbr:dbstruct-get-stime dbstruct))
	(rundb  (dbr:dbstruct-get-rundb dbstruct))
	(inmem  (dbr:dbstruct-get-inmem dbstruct))
	(maindb (dbr:dbstruct-get-main  dbstruct))
	(refdb  (dbr:dbstruct-get-refdb dbstruct))
	(olddb  (dbr:dbstruct-get-olddb dbstruct))
	;; (runid  (dbr:dbstruct-get-run-id dbstruct))
	)
    (if (not local)
	(begin
    (debug:print-info 4 "Syncing for run-id: " run-id)
    ;; (mutex-lock! *http-mutex*)
    (if (eq? run-id 0)
	;; runid equal to 0 is main.db
	(if maindb
	    (if (or (not (number? mtime))
		    (not (number? stime))
		    (> mtime stime)
		    force-sync)
		(begin
		  (db:delay-if-busy maindb)
		  (db:delay-if-busy olddb)
		  (let ((num-synced (db:sync-tables (db:sync-main-list maindb) maindb olddb)))
		    (dbr:dbstruct-set-stime! dbstruct (current-milliseconds))
		    num-synced)
		  0))
	    (begin
	      ;; this can occur when using local access (i.e. not in a server)
	      ;; need a flag to turn it off.
	      ;;
	      (debug:print 3 "WARNING: call to sync main.db to megatest.db but main not initialized")
	      0))
	;; any other runid is a run
	(if (or (not (number? mtime))
		(not (number? stime))
		(> mtime stime)
		force-sync)
	    (begin
	      (db:delay-if-busy rundb)
	      (db:delay-if-busy olddb)
	      (dbr:dbstruct-set-stime! dbstruct (current-milliseconds))
	      (let ((num-synced (db:sync-tables db:sync-tests-only inmem refdb rundb olddb)))
		;; (mutex-unlock! *http-mutex*)
		num-synced)
	      (begin
		;; (mutex-unlock! *http-mutex*)
		0))))))
	  (debug:print-info 4 "Syncing for run-id: " run-id)
	  ;; (mutex-lock! *http-mutex*)
	  (if (eq? run-id 0)
	      ;; runid equal to 0 is main.db
	      (if maindb
		  (if (or (not (number? mtime))
			  (not (number? stime))
			  (> mtime stime)
			  force-sync)
		      (begin
			(db:delay-if-busy maindb)
			(db:delay-if-busy olddb)
			(let ((num-synced (db:sync-tables (db:sync-main-list maindb) maindb olddb)))
			  (dbr:dbstruct-set-stime! dbstruct (current-milliseconds))
			  num-synced)
			0))
		  (begin
		    ;; this can occur when using local access (i.e. not in a server)
		    ;; need a flag to turn it off.
		    ;;
		    (debug:print 3 "WARNING: call to sync main.db to megatest.db but main not initialized")
		    0))
	      ;; any other runid is a run
	      (if (or (not (number? mtime))
		      (not (number? stime))
		      (> mtime stime)
		      force-sync)
		  (begin
		    (db:delay-if-busy rundb)
		    (db:delay-if-busy olddb)
		    (dbr:dbstruct-set-stime! dbstruct (current-milliseconds))
		    (let ((num-synced (db:sync-tables db:sync-tests-only inmem refdb rundb olddb)))
		      ;; (mutex-unlock! *http-mutex*)
		      num-synced)
		    (begin
		      ;; (mutex-unlock! *http-mutex*)
		      0)))))
	0 ;; not local, return 0 sync'd
	)))

(define (db:close-main dbstruct)
  (let ((maindb (dbr:dbstruct-get-main dbstruct)))
    (if maindb
	(begin
	  (sqlite3:finalize! (db:dbdat-get-db maindb))
	  (dbr:dbstruct-set-main! dbstruct #f)))))

Modified http-transport.scm from [d387fec12a] to [6ee712968b].

424
425
426
427
428
429
430
431

432
433
434
435
436
437
438
424
425
426
427
428
429
430

431
432
433
434
435
436
437
438







-
+







	  ;;
	  (if (eq? server-state 'available)
	      (let ((new-server-id (tasks:server-am-i-the-server? (db:delay-if-busy tdbdat) run-id))) ;; try to ensure no double registering of servers
		(if (equal? new-server-id server-id)
		    (begin
		      (tasks:server-set-state! (db:delay-if-busy tdbdat) server-id "dbprep")
		      (thread-sleep! 0.5) ;; give some margin for queries to complete before switching from file based access to server based access
		      (set! *inmemdb*  (db:setup run-id))
		      (set! *inmemdb*  (db:setup run-id local: #t))
		      ;; force initialization
		      ;; (db:get-db *inmemdb* #t)
		      (db:get-db *inmemdb* run-id)
		      (tasks:server-set-state! (db:delay-if-busy tdbdat) server-id "running"))
		    (begin ;; gotta exit nicely
		      (tasks:server-set-state! (db:delay-if-busy tdbdat) server-id "collision")
		      (http-transport:server-shutdown server-id port))))))