Index: db.scm ================================================================== --- db.scm +++ db.scm @@ -377,10 +377,20 @@ (sqlite3:execute db "DELETE FROM runs WHERE id=?;" run-id)) (define (db:update-run-event_time db run-id) (sqlite3:execute db "UPDATE runs SET event_time=strftime('%s','now') WHERE id=?;" run-id)) +(define (db:lock/unlock-run db run-id lock unlock user) + (let ((newlockval (if lock "locked" + (if unlock + "unlocked" + "locked")))) ;; semi-failsafe + (sqlite3:execute db "UPDATE runs SET state=? WHERE id=?;" newlockval run-id) + (sqlite3:execute db "INSERT INTO access_log (user,accessed,args) VALUES(?,strftime('%s','now'),?);" + user (conc newlockval " " run-id)) + (debug:print 1 "INFO: " newlockval " run number " run-id))) + ;;====================================================================== ;; K E Y S ;;====================================================================== ;; get key val pairs for a given run-id Index: megatest.scm ================================================================== --- megatest.scm +++ megatest.scm @@ -34,71 +34,66 @@ license GPL, Copyright Matt Welland 2006-2012 Usage: megatest [options] -h : this help -Process and test running +Launching and managing runs -runall : run all tests that are not state COMPLETED and status PASS, CHECK or KILLED -runtests tst1,tst2 ... : run tests + -remove-runs : remove the data for a run, requires :runname, -testpatt and + -itempatt be set. Optionally use :state and :status + -set-state-status X,Y : set state to X and status to Y, requires controls per -remove-runs + -rerun FAIL,WARN... : force re-run for tests with specificed status(s) + -rollup : fill run (set by :runname) with latest test(s) from + prior runs with same keys + -lock : lock run specified by target and runname + -unlock : unlock run specified by target and runname + +Selectors (e.g. use for -runtests, -remove-runs, -set-state-status, -list-runs etc.) + -target key1/key2/... : run for key1, key2, etc. + -reqtarg key1/key2/... : run for key1, key2, etc. but key1/key2 must be in runconfig + -testpatt patt : % is wildcard + -itempatt patt : % is wildcard + :runname : required, name for this particular test run + :state : Applies to runs, tests or steps depending on context + :status : Applies to runs, tests or steps depending on context -Run status updates (these require that you are in a test directory - and you have sourced the \"megatest.csh\" or - \"megatest.sh\" file.) +Test helpers (for use inside tests) -step stepname -test-status : set the state and status of a test (use :state and :status) -setlog logfname : set the path/filename to the final log relative to the test directory. may be used with -test-status -set-toplog logfname : set the overall log for a suite of sub-tests -summarize-items : for an itemized test create a summary html -m comment : insert a comment for this test -Run data - -target key1/key2/... : run for key1, key2, etc. - -reqtarg key1/key2/... : run for key1, key2, etc. but key1/key2 must be in runconfig - :runname : required, name for this particular test run - :state : required if updating step state; e.g. start, end, completed - :status : required if updating step status; e.g. pass, fail, n/a - -Values and record errors and warnings - -set-values : update or set values in the megatest db +Test data capture + -set-values : update or set values in the testdata table :category : set the category field (optional) :variable : set the variable name (optional) :value : value measured (required) :expected : value expected (required) :tol : |value-expect| <= tol (required, can be <, >, >=, <= or number) :units : name of the units for value, expected_value etc. (optional) -Arbitrary test data loading -load-test-data : read test specific data for storage in the test_data table from standard in. Each line is comma delimited with four fields category,variable,value,comment Queries -list-runs patt : list runs matching pattern \"patt\", % is the wildcard - -testpatt patt : in list-runs show only these tests, % is the wildcard - -itempatt patt : in list-runs show only tests with items that match patt -showkeys : show the keys used in this megatest setup -test-paths targpatt : get the most recent test path(s) matching targpatt e.g. %/%... returns list sorted by age ascending, see examples below Misc - -force : override some checks - -remove-runs : remove the data for a run, requires :runname, -testpatt and - -itempatt be set. Optionally use :state and :status - -set-state-status X,Y : set state to X and status to Y, requires controls per -remove-runs - -rerun FAIL,WARN... : re-run if called on a test that previously ran -rebuild-db : bring the database schema up to date - -rollup : fill run (set by :runname) with latest test(s) from - prior runs with same keys - -lock : lock the run specified by target and runname as locked - which prevents -remove-runs from removing the run -update-meta : update the tests metadata for all tests -env2file fname : write the environment to fname.csh and fname.sh -setvars VAR1=val1,VAR2=val2 : Add environment variables to a run NB// these are overwritten by values set in config files. - -archive : archive tests, use -target, :runname, -itempatt and -testpatt -server -|hostname : start the server (reduces contention on megatest.db), use - to automatically figure out hostname -repl : start a repl (useful for extending megatest) Spreadsheet generation @@ -107,15 +102,10 @@ will clear the field if no rundir/testname/itempath/logfile if it contains forward slashes the path will be converted to windows style Helpers (these only apply in test run mode) - -runstep stepname ... : take remaining params as comand and execute as stepname - log will be in stepname.log. Best to put command in quotes - -logpro file : with -exec apply logpro file to stepname.log, creates - stepname.html and sets log to same - If using make use stepname_logpro.log as your target Examples # Get test paths megatest -test-paths -target ubuntu/n%/no% :runname w49% -testpatt test_mt% @@ -179,10 +169,11 @@ "-gui" ;; misc "-archive" "-repl" "-lock" + "-unlock" ;; queries "-test-paths" ;; get path(s) to a test, ordered by youngest first "-runall" ;; run all tests "-remove-runs" @@ -422,10 +413,11 @@ args:arg-hash)))) ;;====================================================================== ;; Rollup into a run ;;====================================================================== + (if (args:get-arg "-rollup") (general-run-call "-rollup" "rollup tests" (lambda (db target runname keys keynames keyvallst) @@ -432,10 +424,27 @@ (runs:rollup-run db keys (keys->alist keys "na") (args:get-arg ":runname") user)))) + +;;====================================================================== +;; Lock or unlock a run +;;====================================================================== + +(if (or (args:get-arg "-lock")(args:get-arg "-unlock")) + (general-run-call + (if (args:get-arg "-lock") "-lock" "-unlock") + "lock/unlock tests" + (lambda (db target runname keys keynames keyvallst) + (runs:handle-locking db + target + keys + (args:get-arg ":runname") + (args:get-arg "-lock") + (args:get-arg "-unlock") + user)))) ;;====================================================================== ;; Get paths to tests ;;====================================================================== ;; Get test paths matching target, runname, testpatt, and itempatt @@ -561,10 +570,14 @@ (if (args:get-arg "-execute") (begin (launch:execute (args:get-arg "-execute")) (set! *didsomething* #t))) + +;;====================================================================== +;; Test commands (i.e. for use inside tests) +;;====================================================================== (if (args:get-arg "-step") (if (not (getenv "MT_CMDINFO")) (begin (debug:print 0 "ERROR: MT_CMDINFO env var not set, -step must be called *inside* a megatest invoked environment!") @@ -717,10 +730,14 @@ (let ((msg (args:get-arg "-m"))) (rtests:test-set-status! db test-id state newstatus msg otherdata)))) (sqlite3:finalize! db) (set! *didsomething* #t)))) +;;====================================================================== +;; Various helper commands can go below here +;;====================================================================== + (if (args:get-arg "-showkeys") (let ((db #f) (keys #f)) (if (not (setup-for-run)) (begin @@ -756,11 +773,11 @@ (sqlite3:finalize! db) (set! *didsomething* #t))) ;;====================================================================== ;; Update the tests meta data from the testconfig files -;; +;;====================================================================== (if (args:get-arg "-update-meta") (begin (if (not (setup-for-run)) (begin @@ -775,10 +792,11 @@ (set! *didsomething* #t))) ;;====================================================================== ;; Start a repl ;;====================================================================== + (if (args:get-arg "-repl") (let* ((toppath (setup-for-run)) (db (if toppath (open-db) #f))) (if db (begin Index: runs.scm ================================================================== --- runs.scm +++ runs.scm @@ -499,10 +499,13 @@ ;; Remove runs ;; fields are passing in through ;; action: ;; 'remove-runs ;; 'set-state-status +;; +;; NB// should pass in keys? +;; (define (runs:operate-on db action runnamepatt testpatt itempatt #!key (state #f)(status #f)(new-state-status #f)) (let* ((keys (rdb:get-keys db)) (rundat (runs:get-runs-by-patt db keys runnamepatt)) (header (vector-ref rundat 0)) (runs (vector-ref rundat 1)) @@ -644,10 +647,28 @@ (proc db target runname keys keynames keyvallst))) (if th1 (thread-join! th1)) (sqlite3:finalize! db) (set! *didsomething* #t)))))) +;;====================================================================== +;; Lock/unlock runs +;;====================================================================== + +(define (runs:handle-locking db target keys runname lock unlock user) + (let* ((rundat (runs:get-runs-by-patt db keys runname)) + (header (vector-ref rundat 0)) + (runs (vector-ref rundat 1))) + (for-each (lambda (run) + (let ((run-id (db:get-value-by-header run header "id"))) + (if (or lock + (and unlock + (begin + (print "Do you really wish to unlock run " run-id "?\n y/n: ") + (equal? "y" (read-line))))) + (db:lock/unlock-run db run-id lock unlock user) + (debug:print 0 "INFO: Skipping lock/unlock on " run-id)))) + runs))) ;;====================================================================== ;; Rollup runs ;;====================================================================== ;; Update the test_meta table for this test